每日一题---OJ题:分隔链表

片头

嗨!小伙伴们,大家好!今天我们一起来看看这道题----分隔链表

emmmm,这道题,看描述应该不算太难,我们一起来画一画图呗!

题目读懂了,那么如何破解这道题呢?

思路:定义2个链表,大链表和小链表,遍历原链表的节点将其放到对应的新链表中,最后将大链表和小链表首尾相连。

第一次:

第二次:

第三次:

第四次:

第五次:

第六次:

OK,现在pcur在原链表中,已经走到NULL的位置,循环结束,部分代码如下:

复制代码
         typedef struct ListNode ListNode;
        //如果链表为空,返回空
        if(head == NULL){
            return head;
        }

        //pcur遍历原链表
        ListNode* pcur = head;
        //创建小链表,创建小链表的哨兵节点
        ListNode* lessHead = NULL;
        ListNode* lessTail = NULL;
        lessHead = lessTail =(ListNode*) malloc(sizeof(ListNode));

        //创建大链表,创建大链表的哨兵节点
        ListNode* greateHead = NULL;
        ListNode* greateTail = NULL;
        greateHead = greateTail =(ListNode*) malloc(sizeof(ListNode));

        //当pcur遍历到空时,退出循环
        while(pcur!=NULL){
            if(pcur->val < x){
                //尾插到小链表中
                lessTail->next = pcur;
                lessTail = pcur;
            }else{
                //尾插到大链表中
                greateTail->next = pcur;
                greateTail = pcur;
            }
               //pcur指向下一个节点
            pcur = pcur->next;
        }

接下来,我们需要让greateTail的next指针指向NULL,如果不置为NULL的话,就会形成一个环,

下一步,怎么让小链表和大链表连接起来呢?很简单,让lessTail->next = greateHead->next就可以啦!

最后一步,就是用一个节点来保存第一个节点,把2个哨兵节点释放,返回第一个有效节点就可以啦!

复制代码
ListNode* ret = lessHead->next;
free(lessHead);
free(greateHead);
return ret;

OK,这道题被我们解决了,完整代码如下:

复制代码
 typedef struct ListNode ListNode;
struct ListNode* partition(struct ListNode* head, int x) {
        //如果链表为空,返回空
        if(head == NULL){
            return head;
        }

        //pcur遍历原链表
        ListNode* pcur = head;
        //创建小链表,创建小链表的哨兵节点
        ListNode* lessHead = NULL;
        ListNode* lessTail = NULL;
        lessHead = lessTail =(ListNode*) malloc(sizeof(ListNode));

        //创建大链表,创建大链表的哨兵节点
        ListNode* greateHead = NULL;
        ListNode* greateTail = NULL;
        greateHead = greateTail =(ListNode*) malloc(sizeof(ListNode));

        //当pcur遍历到空时,退出循环
        while(pcur!=NULL){
            if(pcur->val < x){
                //尾插到小链表中
                lessTail->next = pcur;
                lessTail = pcur;
            }else{
                //尾插到大链表中
                greateTail->next = pcur;
                greateTail = pcur;
            }
               //pcur指向下一个节点
            pcur = pcur->next;
        }
            //大链表最后一个结点的next指针指向NULL
           greateTail->next = NULL;
           //小链表最后一个节点指向大链表的第一个有效节点
         lessTail->next = greateHead->next;
            
            //用ret来保存小链表的第一个有效节点
        ListNode* ret = lessHead->next;
            //将哨兵节点释放
        free(lessHead);
        free(greateHead);
            //将ret返回
        return ret;
}

片尾

今天我们学习了一道OJ题---分隔链表,希望看完这篇文章能对友友们有所帮助!!!

点赞收藏和关注!!!

谢谢大家!!!

相关推荐
西望云天9 小时前
The 2024 ICPC Asia Nanjing Regional Contest(2024南京区域赛EJKBG)
数据结构·算法·icpc
wdfk_prog14 小时前
[Linux]学习笔记系列 -- lib/timerqueue.c Timer Queue Management 高精度定时器的有序数据结构
linux·c语言·数据结构·笔记·单片机·学习·安全
zhuzhuxia⌓‿⌓14 小时前
线性表的顺序和链式存储
数据结构·c++·算法
高山有多高15 小时前
栈:“后进先出” 的艺术,撑起程序世界的底层骨架
c语言·开发语言·数据结构·c++·算法
YouEmbedded15 小时前
解码查找算法与哈希表
数据结构·算法·二分查找·散列表·散列查找·线性查找
小秋学嵌入式-不读研版16 小时前
C61-结构体数组
c语言·开发语言·数据结构·笔记·算法
Nix Lockhart17 小时前
《算法与数据结构》第七章[算法3]:图的最小生成树
c语言·数据结构·算法
拾光Ծ19 小时前
【C++】STL有序关联容器的双生花:set/multiset 和 map/multimap 使用指南
数据结构·c++·算法
西望云天20 小时前
The 2023 ICPC Asia Shenyang Regional Contest(2023沈阳区域赛CEJK)
数据结构·算法·icpc