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

首頁 > 學院 > 開發設計 > 正文

Leetcode 148. Sort List

2019-11-11 07:00:20
字體:
來源:轉載
供稿:網友

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要每次用快慢指針找中點!把一個鏈表從中間分開成兩個鏈表,分別排序,然后再merge到一起。

class Solution {public: ListNode* sortList(ListNode* head) { // if(!head||!head->next) return head; ListNode* fast=head->next,*slow=head; //step 1: 找中點 while(fast&&fast->next){ fast=fast->next->next; slow=slow->next; } ListNode* l=head,*r=slow->next; if(slow->next) slow->next=NULL;//斷開兩個鏈表 //step 2: recursive排序 ListNode* nl=sortList(l); ListNode* nr=sortList(r); //step 3: merge左右 //ListNode* dummy=new ListNode(0);//bug:下面這幾行不對。正確的做法是:建一個dummy節點,然后用一個指針指向這個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; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通榆县| 沙湾县| 宜宾市| 隆林| 鄂伦春自治旗| 临泽县| 榆树市| 青龙| 新野县| 隆安县| 庐江县| 敦煌市| 侯马市| 万宁市| 保康县| 蕉岭县| 饶河县| 平潭县| 曲周县| 永靖县| 桐柏县| 衢州市| 调兵山市| 怀宁县| 墨竹工卡县| 石林| 汉川市| 阿克| 闸北区| 沾益县| 武邑县| 孝义市| 教育| 根河市| 唐海县| 白朗县| 宁国市| 德庆县| 定日县| 左权县| 巫山县|