每日一题(LeetCode)----链表--分隔链表

每日一题(LeetCode)----链表--分隔链表

1.题目(86. 分隔链表

给你一个链表的头节点 head 和一个特定值 x ,请你对链表进行分隔,使得所有 小于 x 的节点都出现在 大于或等于 x 的节点之前。

你应当 保留 两个分区中每个节点的初始相对位置。

示例 1:

c++ 复制代码
输入:head = [1,4,3,2,5,2], x = 3
输出:[1,2,2,4,3,5]

示例 2:

c++ 复制代码
输入:head = [2,1], x = 2
输出:[1,2]

提示:

  • 链表中节点的数目在范围 [0, 200]
  • -100 <= Node.val <= 100
  • -200 <= x <= 200

2.解题思路

思路一

将这个链表进行拆分,然后合并
1.拆分

把比目标值小的节点存一个链表里,把比目标值大的节点另一个链表里

2.合并

把存比目标值大的节点的链表接到存比目标值小的节点的链表的后面

思路二:快排的思想:区间分割法
1.申请一个虚拟节点,且这个虚拟节点指向头节点,然后这个虚拟节点作为小区间(比目标值小的节点的空间)的尾节点
2.遍历链表进行节点的改变来得到所要的答案链表
遍历链表,看当前链表中的值是否小于目标值

如果大于,那么pre指向当前节点,然后继续遍历

如果小于,那么看pre所指向的节点是否是小区间的尾节点

如果是,那么pre指向当前节点,然后继续遍历

如果不是 ,(1)我们让pre指向的那个节点的下一个节点变为为当前节点的下一个节点

​ (2)当前节点指向小区间尾节点的下一个节点,然后小区间的尾节点再指向当节点 (3)小区间的尾节点向后移动一个节点,下一次要遍历的节点为pre所指向节点的下一个节点

3.写出代码

思路一的代码
c++ 复制代码
class Solution {
public:
    ListNode* partition(ListNode* head, int x) {
        if(head==nullptr||head->next==nullptr){
            return head;
        }
        //遍历一遍链表拆成两个链表
        ListNode* head1=nullptr;
        ListNode* head2=nullptr;
        ListNode* tail1=nullptr;
        ListNode* tail2=nullptr;
        while(head){
            if(head->val<x){
                if(head1==nullptr){
                    head1=tail1=head;
                }
                else{
                    tail1->next=head;
                    tail1=tail1->next;
                }
            }
            else{
                if(head2==nullptr){
                    head2=tail2=head;
                }
                else{
                    tail2->next=head;
                    tail2=tail2->next;
                }
            }
            head=head->next;
        }
        if(tail1){
            tail1->next=nullptr;
        }
        if(tail2){
            tail2->next=nullptr;
        }
        if(tail1){
            tail1->next=head2;
            return head1;
        }
        else{
            return head2;
        }
    }
};
思路二的代码
c++ 复制代码
class Solution {
public:
    ListNode* partition(ListNode* head, int x) {
        if(head ==nullptr || head->next==nullptr){
            return head;
        }
        ListNode* dummyhead = new ListNode(0,head);
        ListNode* prevtail = dummyhead,*prev = dummyhead,*curr = head;
        while(curr){
            if(curr->val < x){
                if(prev != prevtail){
                    prev->next = curr->next;
                    curr->next = prevtail->next;
                    prevtail->next = curr;
                    prevtail = prevtail->next;
                    curr = prev->next;
                }else{
                    prev = prevtail = curr;
                    curr = curr->next;
                }  
            }else{
                prev = curr;
                curr = curr->next;
            }
        }
        return dummyhead->next;
    }
};
相关推荐
YuTaoShao7 分钟前
【LeetCode 每日一题】3634. 使数组平衡的最少移除数目——(解法一)排序+滑动窗口
算法·leetcode·排序算法
波波00714 分钟前
每日一题:.NET 的 GC是如何分代工作的?
算法·.net·gc
风暴之零24 分钟前
变点检测算法PELT
算法
深鱼~24 分钟前
视觉算法性能翻倍:ops-cv经典算子的昇腾适配指南
算法·cann
李斯啦果25 分钟前
【PTA】L1-019 谁先倒
数据结构·算法
梵刹古音30 分钟前
【C语言】 指针基础与定义
c语言·开发语言·算法
啊阿狸不会拉杆1 小时前
《机器学习导论》第 5 章-多元方法
人工智能·python·算法·机器学习·numpy·matplotlib·多元方法
R1nG8632 小时前
CANN资源泄漏检测工具源码深度解读 实战设备内存泄漏排查
数据库·算法·cann
_OP_CHEN2 小时前
【算法基础篇】(五十六)容斥原理指南:从集合计数到算法实战,解决组合数学的 “重叠难题”!
算法·蓝桥杯·c/c++·组合数学·容斥原理·算法竞赛·acm/icpc
TracyCoder1232 小时前
LeetCode Hot100(27/100)——94. 二叉树的中序遍历
算法·leetcode