148. 排序链表

在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序。

示例 1:

输入: 4->2->1->3
输出: 1->2->3->4

示例 2:

输入: -1->5->3->4->0
输出: -1->0->3->4->5

思路:

由复杂度可想到归并排序,归并排序最重要的merge步骤在链表下可以实现O(1)的空间复杂度,具体实现如下。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode* sortList(ListNode* head) {
        if(!head)
        {
            return nullptr;
        }
        int count=0;
        ListNode* p=head;
        while(p)
        {
            count++;
            p=p->next;
        }
        return sort(head,0,count-1);
    }
    ListNode* sort(ListNode* head,int start,int end)
    {
        if(start>=end)
        {
            return head; 
        }
        int mid=start+(end-start)/2;
        ListNode* left=head;
        ListNode* right=head;
        int count=0;
        while(count<mid-start)
        {
            right=right->next;
            count++;
        }
        ListNode* temp=right;
        right=right->next;
        temp->next=nullptr;
        ListNode* l1=sort(left,start,mid);
        ListNode* l2=sort(right,mid+1,end);
        return merge(l1,l2);
    }
    ListNode* merge(ListNode* l1,ListNode* l2)
    {
        ListNode* head=new ListNode(0);
        ListNode* p=head;
        while(l1 && l2)
        {
            if(l1->val<l2->val)
            {
                p->next=l1;
                l1=l1->next;
            }
            else
            {
                p->next=l2;
                l2=l2->next;
            }
            p=p->next;
        }
        if(l1)
        {
            p->next=l1;
        }
        if(l2)
        {
            p->next=l2;
        }
        return head->next;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 148. 排序链表在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序。示例:输入: 4->2...
    杏仁小核桃阅读 431评论 0 1
  • 在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序。 示例 1: 输入: 4->2->1->...
    one_zheng阅读 1,030评论 0 0
  • 本题考察的归并排序(或插入排序)和链表操作 题目描述 在 O(n log n) 时间复杂度和常数级空间复杂度下,对...
    小怪兽大作战阅读 480评论 0 2
  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 6,053评论 0 13
  • 在 O(n log n) 时间复杂度和常数级空间复杂度下,对链表进行排序。 示例 1: 示例 2: 代码
    vbuer阅读 130评论 0 0