本文首发于公众号「五分钟学算法」,是图解 LeetCode 系列文章之一。git
我的网站:www.cxyxiaowu.comgithub
题目来源于 LeetCode 上第 86 号问题:分割链表。题目难度为 Easy,目前经过率为 47.8% 。算法
给定一个链表和一个特定值 x,对链表进行分隔,使得全部小于 x 的节点都在大于或等于 x 的节点以前。bash
你应当保留两个分区中每一个节点的初始相对位置。动画
示例:网站
输入: head = 1->4->3->2->5->2, x = 3
输出: 1->2->2->4->3->5
复制代码
这道题要求咱们划分链表,把全部小于给定值的节点都移到前面,大于该值的节点顺序不变,至关于一个局部排序的问题。ui
dummyHead1
用来保存小于于该值的链表,dummyHead2
来保存大于等于该值的链表dummyHead1
中,其他的放置在dummyHead2
中dummyHead2
插入到dummyHead1
后面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;
}
};
复制代码