Sort List

Description:

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


思路:

这是一道简单的单链表操作的题目。可以采用归并排序,单链表的归并排序,关键在于把原链表分为两半,可以采用快慢双指针法,快指针走两步,慢指针走一步,这样知道快指针为空时,慢指针所指的就是整个链表的中点。即可把链表一分为二。


Solution:/**
* 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==NULL)return NULL;
if(head->next==NULL)return head;
if(head->next->next==NULL)
{
if(head->val>head->next->val)swap(head->val,head->next->val);
return head;
}
ListNode *F,*S;
F=S=head;
while(F)
{
if(F)F=F->next;
if(F)F=F->next;
else break;
if(S)S=S->next;
}
if(S==NULL)return head;
F=S->next;
S->next=NULL;
S=sortList(head);
F=sortList(F);
if(S==NULL)return F;
if(F==NULL)return S;
ListNode *res;
if(S->val<F->val)head=S,S=S->next;
else head=F,F=F->next;
res=head;
while(S && F)
{
if(S->val<F->val)head->next=S,head=S,S=S->next;
else head->next=F,head=F,F=F->next;
}
if(S==NULL)head->next=F;
if(F==NULL)head->next=S;
return res;
}
};

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值