Leetcode-86.单链表的分解
86. 分隔链表 - 力扣(LeetCode)
给你一个链表的头节点 head
和一个特定值 x
,请你对链表进行分隔,使得所有 小于 x
的节点都出现在 大于或等于 x
的节点之前。
你应当 保留 两个分区中每个节点的初始相对位置。
示例 1:

1 2
| 输入:head = [1,4,3,2,5,2], x = 3 输出:[1,2,2,4,3,5]
|
示例 2:
1 2
| 输入:head = [2,1], x = 2 输出:[1,2]
|
提示:
- 链表中节点的数目在范围
[0, 200]
内
-100 <= Node.val <= 100
-200 <= x <= 200
解法
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| class Solution { public: ListNode* partition(ListNode* head, int x) { ListNode* dummy1 = new ListNode(-1); ListNode* dummy2 = new ListNode(-1); ListNode* p1 = dummy1, *p2 = dummy2; ListNode* p = head; while (p != nullptr) { if (p->val >= x) { p2->next = p; p2 = p2->next; } else { p1->next = p; p1 = p1->next; } ListNode* temp = p->next; p->next = nullptr; p = temp; } p1->next = dummy2->next;
return dummy1->next; } };
|