86.分隔链表
【LetMeFly】86.分隔链表
力扣题目链接:https://leetcode.cn/problems/partition-list/
给你一个链表的头节点 head
和一个特定值 x
,请你对链表进行分隔,使得所有 小于 x
的节点都出现在 大于或等于 x
的节点之前。
你应当 保留 两个分区中每个节点的初始相对位置。
示例 1:
输入:head = [1,4,3,2,5,2], x = 3 输出:[1,2,2,4,3,5]
示例 2:
输入:head = [2,1], x = 2 输出:[1,2]
提示:
- 链表中节点的数目在范围
[0, 200]
内 -100 <= Node.val <= 100
-200 <= x <= 200
方法一:双指针
这一题我们只需要把原始链表依据“是否小于x”的规则分成两个链表,再把两个链表合并即可。
首先定义两个新的头节点,遍历原始链表,把每个节点分别添加到新的对应的链表中。
最后,把“小于x的链表”的最后一个节点的next指向“大于等于x的链表”的第一个节点,把“大于等于x的链表”的最后一个节点的next置空,返回“小于x的链表”的第一个节点即可。
具体实现可详见代码注释。
- 时间复杂度$O(N)$,其中$N$是原始链表的节点个数
- 空间复杂度$O(1)$,只需要常数个节点(把节点添加到链表尾部只需要修改next指针,并不需要额外的空间)
AC代码
C++
1 |
|
同步发文于CSDN,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/125467594
86.分隔链表
https://blog.letmefly.xyz/2022/06/26/LeetCode 0086.分隔链表/