[leetcode-每日一题] 86. 分隔链表

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的后面,通过维护这三个指针来完成链表的分隔,执行过程如下:

  1. 如果pos = NULL。并且当前链表p值大于等于x,则将pos指向pre,下一个小于x的节点将接在pos后面。
  2. 如果pos != NULL并且p->val < x,就将当前节点移动到pos后面
  3. 不满足以上两种情况就向后遍历
    如此一来遍历完整个链表就完成了分隔

官方题解

这种感觉好理解一点,维护两个链表,一个链表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;
    }
};