LeetCode热题100-排序链表

给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表

示例 1:

复制代码
输入:head = [4,2,1,3]
输出:[1,2,3,4]
核心思路(3 步记住)

1. 分:找中点 + 切分

  • 快慢指针:快指针走 2 步,慢指针走 1 步
  • 快指针到末尾时,慢指针就在中点
  • 断开链表,分成左右两半

2. 治:递归排序两边

递归把左右链表都变成有序链表

3. 合:合并两个有序链表

和有序链表合并题逻辑一样,用 ** 虚拟头节点(dummy)** 轻松合并

python 复制代码
class Solution:
    def sortList(self, head: Optional[ListNode]) -> Optional[ListNode]:
        if not head or not head.next:
            return head
        mid = self.find_mid(head)
        right_head = mid.next
        mid.next = None
        left = self.sortList(head)
        right = self.sortList(right_head)
        return self.merge(left, right)    

    def find_mid(self, head):
        slow = head
        fast = head.next
        while fast and fast.next:
            slow = slow.next
            fast = fast.next.next
        return slow
    
    def merge(self, l1, l2):
        dummy = ListNode()
        cur = dummy
        while l1 and l2:
            if l1.val < l2.val:
                cur.next = l1
                l1 = l1.next
            else:
                cur.next = l2
                l2 = l2.next
            cur = cur.next
        cur.next = l1 if l1 else l2
        return dummy.next
相关推荐
都在酒里8 小时前
算法总结(二)深入浅出 PID 控制算法:原理、优化与 STM32 标准库实现
stm32·算法·pid算法·位置pid·增式pid
Sinsa_SI8 小时前
2026算法应用主题赛初赛-小学4-6组(c++)试卷(含答案+详细解析)
java·c++·算法
代码中介商8 小时前
哈夫曼树:高效压缩数据的秘密武器
数据结构·算法
sheeta19988 小时前
LeetCode 每日一题笔记 日期:2026.05.22 题目:33. 搜索旋转排序数组
笔记·算法·leetcode
练习时长一年8 小时前
LeetCode热题100之缺失的第一个正数
数据结构·算法·leetcode
Severus_black8 小时前
【初阶数据结构与算法】八大排序之插入排序(直接插入、希尔),一次性讲清!
数据结构·算法·排序算法
菜菜的顾清寒8 小时前
力扣HOT100(27) 合并两个有序链表
数据结构·链表
鱼子星_8 小时前
【数据结构与算法】数据结构基础——树(上):树的存储结构,满二叉树,完全二叉树,二叉树的存储结构
c语言·数据结构·算法
高级c8 小时前
MindIE 推理引擎架构解析
深度学习·算法·架构·cann