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;
    }
};
相关推荐
来深圳1 小时前
leetcode 739. 每日温度
java·算法·leetcode
yaoh.wang1 小时前
力扣(LeetCode) 104: 二叉树的最大深度 - 解法思路
python·程序人生·算法·leetcode·面试·职场和发展·跳槽
hetao17338371 小时前
2025-12-21~22 hetao1733837的刷题笔记
c++·笔记·算法
醒过来摸鱼2 小时前
递归三种分类方法
算法
炽烈小老头2 小时前
【每天学习一点算法 2025/12/22】将有序数组转换为二叉搜索树
学习·算法
jghhh012 小时前
POCS(凸集投影)算法解决部分k空间数据缺失导致吉布斯伪影
算法
罗湖老棍子2 小时前
最小函数值(minval)(信息学奥赛一本通- P1370)
数据结构·c++·算法··优先队列·
LYFlied2 小时前
【每日算法】LeetCode 4. 寻找两个正序数组的中位数
算法·leetcode·面试·职场和发展
长安er2 小时前
LeetCode 62/64/5/1143多维动态规划核心题型总结
算法·leetcode·mybatis·动态规划
鹿角片ljp2 小时前
力扣 83: 删除排序链表中的重复元素(Java实现)
java·leetcode·链表