日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Sort List[leetcode] 由归并排序的递归和循环,到本题的两种解法

發布時間:2025/3/15 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Sort List[leetcode] 由归并排序的递归和循环,到本题的两种解法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

歸并排序能夠有兩種思路----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

總結

以上是生活随笔為你收集整理的Sort List[leetcode] 由归并排序的递归和循环,到本题的两种解法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 粉嫩av一区二区夜夜嗨 | 乌克兰做爰xxxⅹ性视频 | 成人性色生活片 | 中文字幕人妻色偷偷久久 | 综合色在线观看 | 日本免费三片在线播放 | 亚洲精品视屏 | 巨乳美女在线 | 日本xxxxxxxxx| 五月婷婷丁香综合 | 一级免费a | 久久不射网站 | xxxxx黄色| 狠狠干欧美 | 国产一区二区三区观看 | 亚洲av成人无码一区二区三区在线观看 | 亚洲AV无码精品色毛片浪潮 | 在线观看福利网站 | 韩国美女视频在线观看18 | 人人妻人人澡人人爽人人欧美一区 | 日本一区二区视频在线播放 | 亚洲综合一区中 | 久久久99精品国产一区二区三区 | 国产精品卡一 | 双性人妖互交localhost | 国产精品无码毛片 | 五月婷综合网 | 最新av女优| 国产一区二区在线观看视频 | 成人动漫在线播放 | 国产一区二区三区视频在线观看 | 国产激情一区二区三区四区 | 老牛影视一区二区三区 | 毛片网络 | 麻豆成人91精品二区三区 | 色妞欧美| 日韩av不卡在线观看 | 看黄色大片 | 色碰视频| 国产毛片毛片毛片毛片 | 一本色道久久加勒比精品 | 天天夜夜人人 | 国产欧美在线一区 | 999国产在线 | 黄色一集片 | 亚洲精品嫩草 | 麻豆一区二区 | 手机在线一区二区 | 亚洲区精品 | 综合久久久久久久久久久 | 欧美日韩国产一区二区 | 在线观看免费日韩av | 极品销魂美女少妇尤物 | 日本一区二区视频在线播放 | 欧美激情黄色 | 毛片视频免费观看 | 丝袜毛片| av生活片| 中国一级特黄真人毛片免费观看 | 深夜小视频在线观看 | 日韩国产91 | 色六月婷婷| 干干天天 | 亚洲国产成人精品女人久久久 | 久久成人一区 | 亚洲插插插 | 日韩aⅴ片 | 伊人网址 | 国产香蕉一区 | 秋霞黄色片| 欧美综合激情 | 国产真人做爰毛片视频直播 | 成人网战 | 国产视频69 | 国产成人av网站 | 国产成人无码aa精品一区 | 久久久久夜 | 99成人免费视频 | 国产91精品一区二区绿帽 | 久久毛片基地 | 久久精品aⅴ无码中文字字幕重口 | 91美女片黄在线观看 | 我们俩电影网mp4动漫官网 | 91成人在线观看喷潮 | 91丨九色丨海角社区 | 久热国产在线 | 我想看毛片 | www.插插插.com | 91资源在线视频 | 777奇米四色 | 亚洲精品男人的天堂 | 91久久人澡人人添人人爽欧美 | 日韩精品一线二线三线 | 少妇做爰xxxⅹ性视频 | 黄色的一级片 | 国产一区二区三区精品愉拍 | 麻豆视频免费入口 | 久久mm | 久久伊人99 |