链表排序 -lintcode

在 O(n log n) 时间复杂度和常数级的空间复杂度下给链表排序。

样例

给出 1->3->2->null,给它排序变成 1->2->3->null.

这道题目明显是需要我们用归并进行链表排序。

 C++ Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/**
 * Definition of ListNode
 * class ListNode {
 * public:
 *     int val;
 *     ListNode *next;
 *     ListNode(int val) {
 *         this->val = val;
 *         this->next = NULL;
 *     }
 * }
 */

class  Solution
{
public :
    
/**
     * @param head: The first node of linked list.
     * @return: You should return the head of the sorted linked list,
                    using constant space complexity.
     */

    ListNode *sortList(ListNode *head)
    {
        
// write your code here
         if (head ==  NULL  || head -> next ==  NULL return  head;
        ListNode *mid = findMid(head);
        ListNode *temp = mid -> next;//将链表分成两段
        mid -> next = 
NULL ;
        ListNode *left = sortList(head);
        ListNode *right = sortList(temp);
        
return  merge(left, right);
    }
    ListNode *findMid(ListNode *head)//寻找链表中间结点
    {
        
if (head ==  NULL  || head -> next ==  NULL return  head;
        ListNode *fast = head;
        ListNode *slow = head;
        
while (fast -> next !=  NULL  && fast -> next -> next !=  NULL )
        {
            fast = fast -> next -> next;
            slow = slow -> next;
        }
        
return  slow;
    }
    ListNode *merge(ListNode *left, ListNode *right)//合并链表
    {
        
if (left ==  NULL  && right ==  NULL return   NULL ;
        ListNode *node = 
new  ListNode( 0 );
        ListNode *node1 = node;
        
while (left !=  NULL  && right !=  NULL )
        {
            
if (left -> val < right -> val)
            {
                ListNode *temp = left;
                left = left -> next;
                node1 -> next = temp;
                node1 = node1 -> next;
            }
            
else
            {
                ListNode *temp = right;
                right = right -> next;
                node1 -> next = temp;
                node1 = node1 -> next;
            }
        }
        
if (left !=  NULL ) node1 -> next = left;
        
else  node1 -> next = right;
        
return  node -> next;
    }
};


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值