【C++】CM11 链表分隔

简介: 原来链表最后一个比x大就会把大的那个写到新链表的最后一个去 但是这个的next是指向前面的 就会出现一个环

ઇଓ 欢迎来阅读子豪的博客(剑指offer刷题篇)


☾ ⋆有什么宝贵的意见或建议可以在留言区留言


ღღ欢迎 素质三连 点赞 关注 收藏


❣ฅ码云仓库:补集王子 (YZH_skr) - Gitee.com


链表分割_牛客题霸_牛客网 (nowcoder.com)

https://www.nowcoder.com/practice/0e27e0b064de4eacac178676ef9c9d70?tpId=8&&tqId=11004&rp=2&ru=/activity


12aba95748b64f0384c6a502a42c730a.png


难点


相对顺序不变


思路


运用带哨兵位的头结点(尾插的题尽量都用哨兵位)


定义两个链表


7f7e3346e9e8413a97a6def231b0c61e.png

f3ef1d7600c5480bb61fa2f6b44798f2.png


尾插


35bca58c0a134fedbde0d922c266a36a.png


f2f801a2132d4c448c131446c4464ad0.png

528616979dbf4d3f9277fa55a139a859.png


连接+释放


a3d2c52aa1bc4f4b8d5229c28260813b.png

bc192674bca1484089df5f23fdcb8e54.png

3c531e3e43994c808f1b6102cd82928a.png


考虑极端场景


原来链表最后一个比x大


就会把大的那个写到新链表的最后一个去 但是这个的next是指向前面的 就会出现一个环


 866d5a7aa55e49acb488df0bd2c48b4d.png


需要把最后一个置空


9b55f636f5664fa293a2839efda1bc79.png


整体代码


class Partition {
public:
    ListNode* partition(ListNode* pHead, int x) 
    {
        ListNode *greatertail , *greaterhead, *lesshead, *lesstail;
        greaterhead = greatertail = (struct ListNode*)malloc(sizeof(struct ListNode));    //哨兵位
        lesshead = lesstail = (struct ListNode*)malloc(sizeof(struct ListNode));    //哨兵位
        greaterhead -> next = NULL;
        lesshead ->next = NULL;
        struct ListNode* cur = pHead;    // 工具指针
        while(cur)
        {
            if(cur -> val < x)
            {
                lesstail -> next = cur;
                lesstail = lesstail->next;
            }
            else
            {
                greatertail -> next = cur;
                greatertail = greatertail->next;
            }
                cur = cur->next;
        }
        lesstail->next = greaterhead->next;
        greatertail->next = NULL;   
        struct ListNode* head = lesshead->next;
        free(greaterhead);
        free(lesshead);
        return head;
    }
};


记得 三连哦~

相关文章
|
6月前
|
C++
【链表】还不会用C++实现链表?一文教会你各种链表的实现
【链表】还不会用C++实现链表?一文教会你各种链表的实现
260 0
|
3月前
|
存储 算法
LeetCode第86题分隔链表
文章介绍了LeetCode第86题"分隔链表"的解法,通过创建两个新链表分别存储小于和大于等于给定值x的节点,然后合并这两个链表来解决问题,提供了一种简单易懂且操作原链表的解决方案。
LeetCode第86题分隔链表
|
3月前
|
存储 Python
【Leetcode刷题Python】86.分隔链表
通过使用两个虚拟节点(dummy nodes)来分别收集小于特定值 x 的节点和大于等于 x 的节点,最终将这两部分链表合并起来形成结果链表。
33 0
|
4月前
|
存储 C++
C++的list-map链表与映射表
```markdown C++ 中的`list`和`map`提供链表和映射表功能。`list`是双向链表,支持头尾插入删除(`push_front/push_back/pop_front/pop_back`),迭代器遍历及任意位置插入删除。`map`是键值对集合,自动按键排序,支持直接通过键来添加、修改和删除元素。两者均能使用范围for循环遍历,`map`的`count`函数用于统计键值出现次数。 ```
|
5月前
|
存储 SQL 算法
LeetCode 题目 86:分隔链表
LeetCode 题目 86:分隔链表
|
5月前
|
存储 C++
C++的list-map链表与映射表
这篇教程介绍了C++中`list`链表和`map`映射表的基本使用。`list`链表可通过`push_front()`、`push_back()`、`pop_front()`和`pop_back()`进行元素的添加和删除,使用迭代器遍历并支持在任意位置插入或删除元素。`map`是一个键值对的集合,元素自动按键值排序,可使用下标操作符或`insert()`函数插入元素,通过迭代器遍历并修改键值对,同时提供`count()`方法统计键值出现次数。教程中包含多个示例代码以帮助理解和学习。
|
6月前
|
算法 C++
c++算法学习笔记 (13) 链表
c++算法学习笔记 (13) 链表
|
5月前
|
C++ Python
UE C++ 链表
UE C++ 链表
|
5月前
|
C++ 容器
【C++进阶】深入STL之list:高效双向链表的使用技巧
【C++进阶】深入STL之list:高效双向链表的使用技巧
55 0
|
5月前
|
C++ 安全
高效遍历:C++中分隔字符串单词的3种方法详解与实例
拷贝并交换(Copy-and-Swap)是C++中实现赋值操作符和异常安全拷贝构造函数的技巧。它涉及创建临时对象,使用拷贝构造函数,然后交换数据以确保安全。C++11之前的策略在此后及C++11引入的移动语义和右值引用下仍有效,但后者提供了更高效的实现方式。