【leetcode】链表分割

大家好,我是苏貝,本篇博客带大家刷题,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️


目录

  • [方法1. 不用哨兵位](#方法1. 不用哨兵位)
  • [方法2. 用哨兵位](#方法2. 用哨兵位)

点击查看题目

思路:

将链表分为2个链表list1和list2,list1是小于x的所有节点,list2是剩余的节点。最后将list1的最后一个节点指向list2的第一个节点

1

方法1. 不用哨兵位

c 复制代码
#include <csignal>
class Partition {
  public:
    ListNode* partition(ListNode* pHead, int x) {
        ListNode* list1 = nullptr;
        ListNode* i1 = nullptr;
        ListNode* list2 = nullptr;
        ListNode* i2 = nullptr;
        ListNode* cur = pHead;

        while (cur) {
            if (cur->val < x) {
                if (i1 == nullptr) {
                    i1 = list1 = cur;
                } else {
                    i1->next = cur;
                    i1 = i1->next;
                }
            } else {
                if (i2 == nullptr) {
                    i2 = list2 = cur;
                } else {
                    i2->next = cur;
                    i2 = i2->next;
                }
            }
            cur = cur->next;
        }
        if(list1==nullptr&&list2==nullptr)
            return nullptr;
        if(list1==nullptr&&list2!=nullptr)
            return list2;

        i1->next=list2;
        if(list2==nullptr)
            return list1;
        i2->next=nullptr;
        return list1;
    }
};

2

方法2. 用哨兵位

这种方法就不需要分多钟情况进行讨论,记得最后将开辟的空间释放掉,这是一个好习惯

c 复制代码
#include <csignal>
class Partition {
  public:
    ListNode* partition(ListNode* pHead, int x) {
        ListNode* list1,*i1,*list2,*i2,*cur;
        cur=pHead;
        list1=i1=(ListNode*)malloc(sizeof(ListNode));
        list2=i2=(ListNode*)malloc(sizeof(ListNode));
        while(cur)
        {
            if(cur->val<x){
                i1->next=cur;
                i1=i1->next;
            }
            else{
                i2->next=cur;
                i2=i2->next;
            }
            cur=cur->next;
        }
        i1->next=list2->next;
        i2->next=nullptr;
        pHead=list1->next;
        free(list1);
        free(list2);
        return pHead;
    }
};

好了,那么本篇博客就到此结束了,如果你觉得本篇博客对你有些帮助,可以给个大大的赞👍吗,感谢看到这里,我们下篇博客见❤️

相关推荐
d111111111d39 分钟前
在STM32函数指针是什么,怎么使用还有典型应用场景。
笔记·stm32·单片机·嵌入式硬件·学习·算法
kingmax542120081 小时前
《数据结构C语言:单向链表-链表基本操作(尾插法建表、插入)》15分钟试讲教案【模版】
c语言·数据结构·链表
AI科技星1 小时前
质量定义方程常数k = 4π m_p的来源、推导与意义
服务器·数据结构·人工智能·科技·算法·机器学习·生活
摇摆的含羞草1 小时前
哈希(hash)算法使用特点及常见疑问解答
算法·哈希算法
仰泳的熊猫2 小时前
1077 Kuchiguse
数据结构·c++·算法·pat考试
LYFlied2 小时前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
踏浪无痕2 小时前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试
消失的旧时光-19432 小时前
从 C 链表到 Android Looper:MessageQueue 的底层原理一条线讲透
android·数据结构·链表
夏乌_Wx3 小时前
练题100天——DAY28:找消失的数字+分发饼干
数据结构·算法
lzh200409193 小时前
二叉搜索树与双向链表
数据结构·链表