每日一题---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题---分隔链表,希望看完这篇文章能对友友们有所帮助!!!

点赞收藏和关注!!!

谢谢大家!!!

相关推荐
中华小当家呐7 小时前
算法之常见八大排序
数据结构·算法·排序算法
tju新生代魔迷8 小时前
数据结构:双向链表
数据结构·链表
songx_9910 小时前
leetcode9(跳跃游戏)
数据结构·算法·游戏
学c语言的枫子10 小时前
数据结构——双向链表
c语言·数据结构·链表
Boop_wu11 小时前
[数据结构] 栈 · Stack
数据结构
kk”11 小时前
C语言快速排序
数据结构·算法·排序算法
3壹11 小时前
数据结构精讲:栈与队列实战指南
c语言·开发语言·数据结构·c++·算法
papership12 小时前
【入门级-算法-6、排序算法:选择排序】
数据结构·算法·排序算法
YS_Geo15 小时前
Redis 深度解析:数据结构、持久化与集群
数据结构·数据库·redis
njxiejing15 小时前
Pandas数据结构(DataFrame,字典赋值)
数据结构·人工智能·pandas