
归并
/**
* 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) {
return mergeSort(head);
}
ListNode* mergeSort(ListNode* node){
if(!node||!node->next)
return node;
ListNode* fast=node;
ListNode* slow=node;
ListNode* mid=node;
while(fast && fast->next){
fast=fast->next->next;
mid = slow;
slow=slow->next;
}
mid->next=nullptr;
ListNode* l1=mergeSort(node);
ListNode* l2=mergeSort(slow);
return merge(l1,l2);
}
ListNode* merge(ListNode* l1,ListNode* l2){
ListNode* Head = new ListNode(-1);
ListNode* rear = Head;
while(l1 && l2){
if(l1->val<l2->val){
rear->next=l1;
rear=rear->next;
l1=l1->next;
}
else{
rear->next=l2;
rear=rear->next;
l2=l2->next;
}
}
if(l1)
rear->next=l1;
if(l2)
rear->next=l2;
return Head->next;
}
};
本文详细介绍了一种链表归并排序算法的实现过程。通过递归方式将链表分为两部分,分别进行排序后再合并,实现了链表的有效排序。文章深入解析了归并排序在链表数据结构上的应用。
298

被折叠的 条评论
为什么被折叠?



