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

深圳网站制作公司哪家好网站备案主体负责人

深圳网站制作公司哪家好,网站备案主体负责人,北京网站建设网,想弄个网站✨✨小新课堂开课了#xff0c;欢迎欢迎~✨✨ #x1f388;#x1f388;养成好习惯#xff0c;先赞后看哦~#x1f388;#x1f388; 所属专栏#xff1a;C#xff1a;由浅入深篇 小新的主页#xff1a;编程版小新-CSDN博客 一.priority_queue的介绍 优先级队列被实现… ✨✨小新课堂开课了欢迎欢迎~✨✨ 养成好习惯先赞后看哦~ 所属专栏C由浅入深篇 小新的主页编程版小新-CSDN博客 一.priority_queue的介绍 优先级队列被实现为容器适配器容器适配器就是将特定容器类封装作为其底层容器类queue提供一组特定的成员函数来访问其元素。元素从特定容器的“尾部”弹出其称为优先队列的顶部并且它的第一个元素总是它所包含的元素中最大的。因为默认情况下priority_queue是大堆。 底层容器可以是任何标准容器类模板也可以是其他特定设计的容器类。容器支持随机访问迭代器访问以便始终在内部保持堆结构。容器适配器通过在需要时自动调用算法函数make_heap、push_heap和pop_heap来自动完成此操作。 标准容器类vector和deque满足这些需求。默认情况下如果没有为特定的priority_queue类实例化指定容器类则使用vector。 二.priority_queue的使用 优先级队列默认使用vector作为其底层存储数据的容器在vector上又使用了堆算法将vector中元素构造成堆的结构因此priority_queue就是堆所有需要用到堆的位置都可以考虑使用priority_queue。 注意默认情况下priority_queue是大堆。 2.1priority_queue的定义 1.指定定义 //指定定义 //1.以vector作为底部容器类内部构建大堆结构 priority_queueint, vectorint, lessint pq1;//2.以vector作为底部容器类内部构建小堆结构 priority_queueint, vectorint, greaterint pq2; 2.未指定定义 //未指定定义 priority_queueint pq3;//默认以vector作为底层容器类内部构建大堆结构 2.2priority_queue的常见操作  函数声明接口说明priority_queue()/priority_queue(first, last)构造一个空的优先级队列empty( )检测优先级队列是否为空是返回true否则返回falsetop( )返回优先级队列中最大(最小元素)即堆顶元素push(x)在优先级队列中插入元素xpop()删除优先级队列中最大(最小)元素即堆顶元素 void priority_queue1() {priority_queueint pq1;pq1.push(3);pq1.push(7);pq1.push(2);pq1.push(5);pq1.push(8);pq1.push(1);pq1.push(6);pq1.push(4);//插入while (!pq1.empty()){cout pq1.top() ;//返回堆顶元素pq1.pop();//删除堆顶元素}//8 7 6 5 4 3 2 1 }三.priority_queue的模拟实现 我们在模拟实现priority_queque之前要先复习一下两个堆算法这里我们就以构建大堆结构为例。 3.1向上调整建堆 以大堆为例向上调整建堆就是在堆的末尾插入一个数据后经过向上调整依然是一个大堆。 调整思想 1、将目标结点与其父结点进行比较。 2、若目标结点的值比其父结点的值大则交换目标结点与其父结点的位置并将原目标结点的父结点当作新的目标结点继续进行向上调整直到目标节点的值比其父节点的值小位置位置调整完毕。 3.2向下调整建堆 以大堆为例向下调整算法是为了删除堆顶数据在删除堆顶数据后让该堆依旧是大根堆。 调整思想 1、将目标结点与其较大的子结点进行比较。 2、若目标结点的值比其较大的子结点的值小则交换目标结点与其较大的子结点的位置并将原目标结点的较大子结点当作新的目标结点继续进行向下调整直到目标节点比其较大的子节点的值大为止调整完成。 3.3priority_queue的模拟实现 函数声明接口说明priority_queue()/priority_queue(first, last)构造一个空的优先级队列empty( )检测优先级队列是否为空是返回true否则返回falsetop( )返回优先级队列中最大(最小元素)即堆顶元素push(x)在优先级队列中插入元素xpop()删除优先级队列中最大(最小)元素即堆顶元素 namespace fu {//内部构建大根堆template class Tstruct less{bool opeartor()(const T x, const T y){return x y;}};//内部构建小跟堆template class Tstruct greater{bool opeartor()(const T x, const T y){return x y;}};//优先级队列模拟实现templateclass T, class Container vectorint, class Compare lessTclass priority_queue{public://向上调整建堆void AdjustUp(int child){int parent (child - 1) / 2;while (child 0){if (_com(_con[parent], _con[child])){swap(_con[parent], _con[child]);child parent;parent (child - 1) / 2;}else{break;}}}//插入数据void push(const T x){_con.push_back(x);AdjustUp(x);}//向下调整建堆void AdjustDown(int n, int parent){int child 2 * parent 1;while (child n){if (child 1 n _comp(_con[child], _con[child 1])){child;}if (_com(_con[parent], _con[child])){swap(_con[parent], _con[child]);parent child;child 2 * parent 1;}else{break;}}}//删除数据void pop(){swap(_con[0], _con[_con.size() - 1]);_con.pop_back();AdjustDown(_con.size(),0);}//访问堆顶元素T top(){return _con[0];}const T top() {return _con[0];}//返回有效元素个数size_t size() {return _con.size();}//判断队列是否为空bool empty() {return _con.empty();}private:Container _con;Compare _com;}; }感谢各位大佬的观看创作不易还请各位大佬支持~
http://www.dnsts.com.cn/news/95267.html

相关文章:

  • php做网站的技术难点知乎问答网站开发教程
  • 网站域名费用怎么做帐什么网站管理系统好
  • 网站seo优化有哪些书店网站建设规划书
  • 网站这么建设泰州网站关键词优化软件咨询
  • 建设部网站监理公告网页制作教程和素材
  • 广东网站系统建设企业网站建站技术
  • 注册网站怎么注册app定制开发网站建设
  • 商业网站源码萤火虫网站建设优化
  • 企业内部网站建设方案2023最佳创业商机
  • html怎么做网站地图琼海建设网站
  • 江门免费网站建站模板网站建设哪家售后做的好
  • 健康养生网站源码沈阳高端做网站建设
  • 免费购物网站建设部执业注册中心网站
  • 手机建网站需要多少钱it培训机构一般多少钱
  • 能看任何网站的浏览器网站域名交易
  • iis默认网站启动不了云南省住房和城乡建设厅官方网站
  • 易名网站备案用DW做网站时怎么在新窗口打开
  • 网站建设需要关注什么同一ip网站
  • 米客优品的网站是哪做的做网站张家口
  • 网络营销个人网站wordpress 主机空间
  • 网站建设演讲稿重庆市建设工程信息网安全监督查询
  • 国外的做外包项目的网站wordpress通用页面模板
  • 网站搜索框设计wordpress 插件 安装教程
  • 网站设计公司建设医院网站建设与管理ppt
  • 域名备案关闭网站wordpress页面模板插件
  • 电影网站开发影院座位问题wordpress theme o'connor 下载
  • 一站式网站建设 t云仿wordpress模板教程
  • 全球著名科技网站交通局网站建设整改
  • 安防公司网站模板如何推广app更高效
  • 网站备案管局审核企业网站开发计划书