Leetcode 148. 排序链表 归并排序

原题链接:Leetcode 148. 排序链表


方法一:自顶向下归并排序

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* merge2Lists(ListNode* head1,ListNode* head2){
        if(!head1) return head2;
        if(!head2) return head1;
        if(head1-> val <=  head2->val){
            head1->next = merge2Lists(head1->next,head2);
            return head1;
        }
        else {
            head2->next = merge2Lists(head1,head2->next);
            return head2;
        }
    }
    ListNode* sortList(ListNode* head) {
        if(head==nullptr || head->next==nullptr) return head;
        // 快慢指针找到中间节点
        ListNode * slow = head;
        ListNode * fast = head;
        ListNode * pre = slow;
        while(fast && fast->next){
            pre = slow;
            slow = slow->next;
            fast = fast->next->next;
        }
        // 找到中间节点 slow,断开slow的前一个节点pre和slow的关系,将链表拆分成两个子链表
        pre ->next = nullptr;
        // 对两个子链表分别排序
        head = sortList(head);
        slow = sortList(slow);
        // 合并两个有序链表
        return merge2Lists(head,slow);
    }
};

方法二:自底向上归并排序

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* merge2Lists(ListNode* head1,ListNode* head2){
        if(!head1) return head2;
        if(!head2) return head1;
        if(head1-> val <=  head2->val){
            head1->next = merge2Lists(head1->next,head2);
            return head1;
        }
        else {
            head2->next = merge2Lists(head1,head2->next);
            return head2;
        }
    }
    ListNode* sortList(ListNode* head) {
        if(head==nullptr || head->next==nullptr) return head;
        int n=0;
        ListNode* cur = head;
        while(cur){
            cur=cur->next;
            n++;
        }
        ListNode* root = new ListNode (0,head);
        for(int len=1;len<n;len*=2){
            ListNode* pre = root;
            cur = root->next;
            while(cur!=nullptr){
                ListNode* head1 = cur;
                for(int i=1;i<len && cur->next!=nullptr;i++){
                    cur = cur->next;
                }
                ListNode* head2 = cur->next;
                cur->next = nullptr;
                cur= head2;
                for(int i=1;i<len && cur!=nullptr && cur->next!=nullptr ;i++){
                    cur = cur->next;
                }
                ListNode* nxt = nullptr;
                if(cur!=nullptr){
                    nxt = cur->next;
                    cur->next = nullptr;
                }
                ListNode* merged = merge2Lists(head1,head2);
                pre->next=merged;
                while(pre->next!=nullptr){
                    pre = pre->next;
                }
                cur = nxt;
            }
        }
        return root->next;
    }
};
相关推荐
数研小生6 小时前
构建命令行单词记忆工具:JSON 词库与艾宾浩斯复习算法的完美结合
算法·json
芒克芒克6 小时前
LeetCode 题解:除自身以外数组的乘积
算法·leetcode
Python 老手7 小时前
Python while 循环 极简核心讲解
java·python·算法
@Aurora.7 小时前
优选算法【专题九:哈希表】
算法·哈希算法·散列表
爱看科技7 小时前
微美全息(NASDAQ:WIMI)研究拜占庭容错联邦学习算法,数据安全与隐私保护的双重保障
算法
qq_417129257 小时前
C++中的桥接模式变体
开发语言·c++·算法
YuTaoShao8 小时前
【LeetCode 每日一题】3010. 将数组分成最小总代价的子数组 I——(解法二)排序
算法·leetcode·排序算法
吴维炜10 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
Σίσυφος190011 小时前
PCL Point-to-Point ICP详解
人工智能·算法
玄〤11 小时前
Java 大数据量输入输出优化方案详解:从 Scanner 到手写快读(含漫画解析)
java·开发语言·笔记·算法