国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

Leetcode 148. Sort List

2019-11-11 05:34:09
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

Sort a linked list in O(n log n) time using constant space complexity.

s思路: 1. 排序+鏈表。o(nlgn)的方法有merge sort,quick sort。 2. 用merge sort要每次用快慢指針找中點(diǎn)!把一個(gè)鏈表從中間分開(kāi)成兩個(gè)鏈表,分別排序,然后再merge到一起。

class Solution {public: ListNode* sortList(ListNode* head) { // if(!head||!head->next) return head; ListNode* fast=head->next,*slow=head; //step 1: 找中點(diǎn) while(fast&&fast->next){ fast=fast->next->next; slow=slow->next; } ListNode* l=head,*r=slow->next; if(slow->next) slow->next=NULL;//斷開(kāi)兩個(gè)鏈表 //step 2: recursive排序 ListNode* nl=sortList(l); ListNode* nr=sortList(r); //step 3: merge左右 //ListNode* dummy=new ListNode(0);//bug:下面這幾行不對(duì)。正確的做法是:建一個(gè)dummy節(jié)點(diǎn),然后用一個(gè)指針指向這個(gè)node。 //ListNode* newhead=NULL; //dummy->next=newhead; ListNode dummy(0); ListNode* newhead=&dummy; if(!nl) return nr; if(!nr) return nl; while(nl&&nr){ if(nl->val<nr->val){ newhead->next=nl; nl=nl->next; }else{ newhead->next=nr; nr=nr->next; } newhead=newhead->next; } newhead->next=!nl?nr:nl; return dummy.next; }};
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 高雄县| 神木县| 双柏县| 津市市| 稻城县| 井陉县| 固镇县| 友谊县| 沙田区| 林口县| 龙陵县| 宜兰县| 外汇| 凤冈县| 旺苍县| 江川县| 工布江达县| 清水河县| 文水县| 抚顺市| 白山市| 阜宁县| 宁夏| 永泰县| 万荣县| 渝中区| 吉安县| 文山县| 库伦旗| 石城县| 长沙县| 咸丰县| 花莲县| 张掖市| 台东市| 囊谦县| 江门市| 松溪县| 湄潭县| 子洲县| 板桥市|