leetcode-86 分隔链表
leetcode-86 分隔链表
难度:中等
描述
给你一个链表和一个特定值 x ,请你对链表进行分隔,使得所有小于 x 的节点都出现在大于或等于 x 的节点之前。
你应当保留两个分区中每个节点的初始相对位置。
示例:
输入:head = 1->4->3->2->5->2, x = 3
输出:1->2->2->4->3->5
题解
这个题目还算简单,我做出来之后看官方题解也有种不同实现方法
自己做的
这种属于就地分隔,维护三个指针,p为当前遍历到的指针,pre为当前指针的前一个指针,而下一个小于x的指针应该放到pos的后面,通过维护这三个指针来完成链表的分隔,执行过程如下:
- 如果pos = NULL。并且当前链表p值大于等于x,则将pos指向pre,下一个小于x的节点将接在pos后面。
- 如果pos != NULL并且p->val < x,就将当前节点移动到pos后面
- 不满足以上两种情况就向后遍历
如此一来遍历完整个链表就完成了分隔
官方题解
这种感觉好理解一点,维护两个链表,一个链表ps所有值<x,一个链表pl所有值>=x,然后将pl接在ps后面,就完成了分隔。
Solution:
自己做的
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* partition(ListNode* head, int x) {
ListNode *p, *pre = new ListNode(0),*pos = NULL;
p = head;
pre -> next = head;
head = pre;
while(p){
if(p -> val >= x && pos == NULL){
pos = pre;
}
else if(p -> val < x && pos != NULL){
ListNode *tmp = p;
p = p->next;
pre->next = tmp->next;
tmp->next = pos->next;
pos -> next = tmp;
pos = pos->next;
}
else{
pre = p;
p = p->next;
}
}
return head->next;
}
};
官方题解
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
ListNode* partition(ListNode* head, int x) {
ListNode* small = new ListNode(0);
ListNode* smallHead = small;
ListNode* large = new ListNode(0);
ListNode* largeHead = large;
while (head != nullptr) {
if (head->val < x) {
small->next = head;
small = small->next;
} else {
large->next = head;
large = large->next;
}
head = head->next;
}
large->next = nullptr;
small->next = largeHead->next;
return smallHead->next;
}
};
Comments | 1 条评论