mirror of
https://gitee.com/TheAlgorithms/LeetCodeAnimation.git
synced 2024-12-31 15:25:33 +08:00
75 lines
2.2 KiB
Markdown
75 lines
2.2 KiB
Markdown
# LeetCode 第 86 号问题:分割链表
|
||
|
||
> 本文首发于公众号「五分钟学算法」,是[图解 LeetCode ](<https://github.com/MisterBooo/LeetCodeAnimation>)系列文章之一。
|
||
>
|
||
> 个人网站:[https://www.cxyxiaowu.com](https://www.cxyxiaowu.com)
|
||
|
||
题目来源于 LeetCode 上第 86 号问题:分割链表。题目难度为 Easy,目前通过率为 47.8% 。
|
||
|
||
### 题目描述
|
||
|
||
给定一个链表和一个特定值 *x*,对链表进行分隔,使得所有小于 *x* 的节点都在大于或等于 *x* 的节点之前。
|
||
|
||
你应当保留两个分区中每个节点的初始相对位置。
|
||
|
||
**示例:**
|
||
|
||
```
|
||
输入: head = 1->4->3->2->5->2, x = 3
|
||
输出: 1->2->2->4->3->5
|
||
```
|
||
|
||
### 题目解析
|
||
|
||
这道题要求我们划分链表,把所有小于给定值的节点都移到前面,大于该值的节点顺序不变,相当于一个局部排序的问题。
|
||
|
||
- 设定两个虚拟节点,`dummyHead1 `用来保存小于于该值的链表,`dummyHead2 `来保存大于等于该值的链表
|
||
- 遍历整个原始链表,将小于该值的放于`dummyHead1 `中,其余的放置在`dummyHead2 `中
|
||
- 遍历结束后,将`dummyHead2 `插入到`dummyHead1 `后面
|
||
|
||
### 动画描述
|
||
|
||
![](https://bucket-1257126549.cos.ap-guangzhou.myqcloud.com/20181104095701.gif)
|
||
|
||
### 代码实现
|
||
|
||
```
|
||
class Solution {
|
||
public:
|
||
ListNode* partition(ListNode* head, int x) {
|
||
|
||
ListNode* dummyHead1 = new ListNode(-1);
|
||
ListNode* dummyHead2 = new ListNode(-1);
|
||
ListNode* prev1 = dummyHead1;
|
||
ListNode* prev2 = dummyHead2;
|
||
|
||
for(ListNode* cur = head ; cur != NULL ;){
|
||
if(cur->val < x){
|
||
prev1->next = cur;
|
||
cur = cur->next;
|
||
prev1 = prev1->next;
|
||
prev1->next = NULL;
|
||
}
|
||
else{
|
||
prev2->next = cur;
|
||
cur = cur->next;
|
||
prev2 = prev2->next;
|
||
prev2->next = NULL;
|
||
}
|
||
}
|
||
|
||
prev1->next = dummyHead2->next;
|
||
ListNode* ret = dummyHead1->next;
|
||
|
||
delete dummyHead1;
|
||
delete dummyHead2;
|
||
return ret;
|
||
}
|
||
};
|
||
```
|
||
|
||
|
||
|
||
|
||
|
||
![](https://bucket-1257126549.cos.ap-guangzhou.myqcloud.com/blog/fz0rq.png) |