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

网站语言编程罗定城乡建设局网站

网站语言编程,罗定城乡建设局网站,王也台球,郑州信息网平台归并排序能够有两种思路----top-down 和 bottom-up top-down: 递归实现#xff0c;将数组分成两半。分别处理。再合并。 伪代码例如以下#xff1a; split ( A[], l, r) {if ( r - l 2) return;m (r l) / 2;split ( A, l, m); //split A[l…m-1]split ( A, m, r); //s… 归并排序能够有两种思路----top-down 和 bottom-up top-down: 递归实现将数组分成两半。分别处理。再合并。 伪代码例如以下 split ( A[], l, r) {if ( r - l 2) return;m (r l) / 2;split ( A, l, m); //split A[l…m-1]split ( A, m, r); //split A[m…r-1]merge ( A, l, m, e); //merge A[l…m-1] and A[m…e-1] }bottom-up: 循环实现。将数组看做n个长度为1的组数组。 用width控制每次merge的子数组长度。width每次翻倍 伪代码例如以下 sort ( A[], n) {for (width 1; width n; width * 2){for (i 0; i n; i 2 * width){merge(A, i, min(i width, n), min(i 2 * width, n));}} } Sort list中使用链表。不能在O(1)的时间内訪问随意节点同一时候注意要处理尾部节点的next置为NULL 和上面的伪代码类似首先实现merge函数 ListNode * merge(ListNode * h1, int s1, ListNode * h2, int s2){if (h2 NULL) return h1;ListNode * h;if (h1-val h2-val)h advance(h1, s1);elseh advance(h2, s2);ListNode * cur h;while (s1 s2){if (h1-val h2-val)cur-next advance(h1, s1);elsecur-next advance(h2, s2);cur cur-next;}if (s1){cur-next h1;while(s1) advance(h1, s1);}if (s2){cur-next h2;while(s2) advance(h2, s2);}return h;}ListNode * advance(ListNode * ( n), int size){ListNode * temp n;if (size 1) n-next NULL;n n-next;size--;return temp;}同一时候实现工具函数訪问任何位置节点 ListNode * getNode(ListNode * head, int len){while (len -- head) head head-next;return head;}循环版本号主函数例如以下 ListNode *sortList(ListNode *head) {ListNode * cur head;int size 0;while (cur){size ;cur cur-next;}ListNode * pre;for (int w 1; w size; w * 2){cur head;for (int i 0; i size; i w*2){ListNode * h1 cur, * h2 getNode(cur, w), * next getNode(cur, 2 * w);cur merge(h1, min(w, size - i), h2, min(w, size - i - w));if (i 0) head cur;else pre-next cur;pre getNode(cur, min(2 * w, size - i) - 1);cur next;}}return head;}递归版本号主函数例如以下 ListNode *sortList(ListNode *head) {ListNode * cur head;int size 0;while (cur){size ;cur cur-next;}return sort(head, size - size / 2, getNode(head, size - size / 2), size / 2);}ListNode * sort(ListNode * h1, int s1, ListNode * h2, int s2){if (s1 0) return h2;if (s2 0) return h1;h1 sort(h1, s1 - s1 / 2, getNode(h1, s1 - s1 / 2), s1 / 2);h2 sort(h2, s2 - s2 / 2, getNode(h2, s2 - s2 / 2), s2 / 2);return merge(h1, s1, h2, s2);} 转载于:https://www.cnblogs.com/blfbuaa/p/6743700.html
http://www.zqtcl.cn/news/274683/

相关文章:

  • 成都网站建设 lkcms深圳做网站哪个公司最好
  • 网站降权处理关于网站建设心得体会
  • 互联网站点与wordpress集成软件
  • 网站页面图片布局如何设计最新热点新闻事件
  • 学网站建设难四会市城乡规划建设局网站
  • 网站源码分享网html代码入门基础
  • 农产品网站开发方案陕西建设网成绩查询
  • 网站效益分析iis添加网站ip地址
  • 宣传海报在什么网站做网站建设的能力
  • 温州网站优化优化课程设置
  • 企业推广网站有哪些做百度推广需要什么条件
  • 如何实现网站的快速排名怎么做网站模板
  • 数据型网站建设wordpress 阅读统计
  • a做爰网站集宁建设局网站
  • 黄山建设网站公司电话wordpress微信分享图
  • 大数据网站网站的备案流程图
  • 如果自己做网站wordpress付款插件
  • 网站建设项目的结论网站开发合同适用印花税
  • 网站建设经验与教训普陀网站建设推广
  • 12306网站是是阿里巴巴做的吗专业建网站设计公司
  • 关于申请网站建设经费的请示网推推荐信
  • 网站建设请款报告网站服务器租用价格
  • 贵州建设网老网站手机网站建设运营方案
  • 网站方案范文唐山自助建站模板
  • 金华网站制作网站建设的功能需求
  • 用iis建立网站口碑营销案例分析
  • 注册网站要求线上设计师与线下设计师的区别
  • 个人备案 网站内容网站备案如何查询
  • 宿州科技网站建设百度网站外链发布平台
  • 织梦移动网站wordpress父文章显示不全