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
相关推荐
通信小呆呆5 小时前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
benben0445 小时前
强化学习之DQN算法族(基于gymnasium开发)
算法
何以解忧,唯有..6 小时前
Go语言循环语句详解:for、range与循环控制
开发语言·算法·golang
想吃火锅10057 小时前
【leetcode】88.合并两个有序数组js
算法
生成论实验室8 小时前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Qres8218 小时前
算法复键——树状数组
数据结构·算法
H178535090968 小时前
SolidWorks第四部分_直接实体建模特征9_替换面原理
线性代数·算法·机器学习·3d建模·solidworks
不会就选b8 小时前
算法日常・每日刷题--<二分查找>3
算法
绿算技术9 小时前
Mooncake 与绿算ForinnBase GroundPool如何联手打破推理僵局?
科技·算法·架构