当前位置: 首页 > news >正文

做淘客的网站有哪些直接登录的网站

做淘客的网站有哪些,直接登录的网站,百度seo排名在线点击器,怎么搭建一个自己的网站C语言栈#xff1a;数据结构——栈(C语言版)-CSDN博客 C语言队列#xff1a;数据结构——队列#xff08;C语言版#xff09;-CSDN博客 C栈与队列#xff1a;【C初阶学习】第十二弹——stack和queue的介绍和使用-CSDN博客 前言#xff1a; 在前面#xff0c;我们已经… C语言栈数据结构——栈(C语言版)-CSDN博客 C语言队列数据结构——队列C语言版-CSDN博客 C栈与队列【C初阶学习】第十二弹——stack和queue的介绍和使用-CSDN博客 前言 在前面我们已经学习了用C如何使用stack和queue今天我们来讲解一下它们两个底层实现的一些东西和一些扩展内容 目录 一、优先级队列 基本概念 常用成员函数 创建和使用优先级队列 创建小根堆 二、容器适配器 基本概念 deque容器了解 stack和queue的模拟实现 一、优先级队列 前面我们已经学习了队列的知识队列就是先进先出那么这里的优先级队列是什么呢 C中的优先级队列是一种基于容器适配器的抽象数据类型它提供了队列接口并允许按照元素的优先级进行排序 基本概念 优先级队列是一种特殊的队列其中元素的出队顺序不是按照先进先出的原则而是根据元素的优先级来确定。优先级高的元素先出队优先级低的元素后出队一般是按照升序类似于堆的结构 常用成员函数 以下是优先级队列的一些常用成员函数 empty()检查队列是否为空。size()返回队列中的元素数量。top()返回队列顶部优先级最高的元素但不从队列中删除它。push()将一个元素添加到队列中并重新调整队列以保持排序。pop()删除队列顶部优先级最高的元素。swap()与另一个优先级队列交换内容 创建和使用优先级队列 以下是如何创建和使用一个优先级队列的示例 #include iostream #include queue #include vector using namespace std;int main() {// 创建一个存储int类型元素的优先级队列priority_queueint pq;// 向队列中添加元素pq.push(10);pq.push(30);pq.push(20);pq.push(5);pq.push(1);// 输出队列中的元素并观察优先级while (!pq.empty()) {cout pq.top() ;pq.pop();}cout endl;return 0; } 运行结果 通过这个结果我们就可以看出所谓的优先级队列实际上与我们之前所学的堆很像而且默认的是升序 创建小根堆 如果你想要创建一个小根堆优先级最低的元素在顶部你可以传递std::greaterT作为比较函数 std::priority_queueint, std::dequeueint, std::greaterint pq; 二、容器适配器 基本概念 在将容器适配器前我们首先要搞明白一点 什么是容器什么是容器适配器 在前面我们讲vector、list、string时我们讲过这些我们在以后讲时是将其作为容器使用就是说我们用它们来存放数据哪个用着方便就用哪个至于说容器适配器其实就是指这个类型可以用多种容器来模拟实现比如说 stack是一种后进先出的特殊线性数据结构因此只要具有push_back()和pop_back()操作的线性结构都可 以作为stack的底层容器比如vector和list都可以 queue是先进先出的特殊线性数据结构只要具有 push_back和pop_front操作的线性结构都可以作为queue的底层容器比如list。 当然上面这两个类型在底层设计时使用的并不是vector和list而是用deque来实现的那么这个容器又是什么呢在前面我们就涉及到过下面就来讲一下 deque容器了解 deque本质上是一个双向都可以插入删除的队列更准确的说我们应该拿它与vector和list做对比下面我们来看一下deque的接口函数 通过这个图片我们可以看出其实deque是兼顾vector和list的用法的有点像是它们两个的集大成者那么我们为什么不直接学习deque不去学习vector和list呢 这是因为deque有一个致命缺陷不适合遍历因为在遍历时deque的迭代器要频繁的去检测其是否移动到 某段小空间的边界导致效率低下但是一般用到这种线性结构存储的都会需要遍历所以deque在平时就用不到 下面我们可以来看一下deque的底层架构: 下面我们来看一下deque的应用场景stack和queue的模拟实现 stack和queue的模拟实现 这里不做详细的讲解了有不懂的可以私信问我 stack #includedeque namespace zda {templateclass T, class Con dequeT//templateclass T, class Con vectorT//templateclass T, class Con listTclass stack{public:stack() {}void push(const T x) { _c.push_back(x); }void pop() { _c.pop_back(); }T top() { return _c.back(); }const T top()const { return _c.back(); }size_t size()const { return _c.size(); }bool empty()const { return _c.empty(); }private:Con _c;}; } queue #includedeque #include list namespace bite {templateclass T, class Con dequeT//templateclass T, class Con listTclass queue{public:queue() {}void push(const T x) { _c.push_back(x); }void pop() { _c.pop_front(); }T back() { return _c.back(); }const T back()const { return _c.back(); }T front() { return _c.front(); }const T front()const { return _c.front(); }size_t size()const { return _c.size(); }bool empty()const { return _c.empty(); }private:Con _c;}; } 三、总结 学完我们再回头体会一下其实优先级队列就是我们之前所学的堆而容器适配器其实就是一种能够调用容器的特殊数据类型并没有什么新的知识今天的内容暂且到此有不理解的地方可以与我私信交流 感谢各位大佬观看创作不易还请各位大佬一键三连
http://www.hkea.cn/news/14392628/

相关文章:

  • 网站建设方案书备案设计图山东定制网页建站
  • 修改数据库密码 进不了网站后台中国百强城市榜单发布2021
  • 黄冈网站推广优化找哪家自己在网上怎么做网站
  • NET网站开发程序员招聘社保网站做员工用工备案
  • 网站运营与营销网站备案要求
  • 怎样弄免费网站有服务器有域名怎么做网站
  • 北京网站建设设计公司南京外贸推广
  • 网站建设好了却收不到小欢喜林磊儿什么网站做家教
  • 做网站跳转怎么收费自己公司内网网站和外网怎么做同步
  • 沈阳网站建设q479185700棒网站建设基本流程视频
  • 抚州做网站的公司做商业网站赚钱吗
  • 构建平台还是搭建平台seo引擎优化专员
  • 棋牌网站搭建公司wordpress媒体库搜索
  • 网站做实名验证码建设网站如何挂到网上
  • 360网站做不了网银怎么办c2c电商网站
  • 无锡公共建设中心网站wordpress 插件开启
  • wordpress建立个人网站网页设计首页
  • 下载app 的网站 如何做顺企网查企业电话
  • 微信开放平台 网站开发百度法务部联系方式
  • 如何简述网站建设流程图广西南宁电商网站建设
  • 贵阳市城乡建设厅网站网站面包屑如何做
  • 东莞seo网站建设公司常熟市住房和城乡建设局网站
  • 网站建设程序都有哪些在线网页制作平台
  • 用tornado做网站网站开发中的网页上传和网站发布
  • 泰兴网站建设价格盐城网站优化公司
  • 北京网站制作郑州临海建设局官方网站
  • 吉安律师网站建设做网站设计的电话
  • 万众城网站建设济南高端网站设计
  • 大良制作网站漳州手机网站建设
  • 企业网站数防泄露怎么做文化建设意义