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

点赞收藏和关注!!!

谢谢大家!!!

相关推荐
磊 子20 小时前
笔试面试中关于链表相关的题目
数据结构·链表·面试·职场和发展
Genevieve_xiao1 天前
【数据结构】【xjtuse】八股文单元小测
数据结构·算法
想唱rap1 天前
Linux下进程的状态和优先级
linux·运维·服务器·开发语言·数据结构·算法
Croa-vo1 天前
逆袭Akuna Quant!美硕秋招亲历,从网申到拿offer全攻略
数据结构·经验分享·算法·面试·职场和发展
vir021 天前
交换瓶子(贪心)
数据结构·算法
墨染点香1 天前
LeetCode 刷题【160. 相交链表】
算法·leetcode·链表
YoungHong19921 天前
面试经典150题[066]:分隔链表(LeetCode 86)
leetcode·链表·面试
952361 天前
数据结构-二叉树
java·数据结构·学习
HUTAC1 天前
重要排序算法(更新ing)
数据结构·算法
冉佳驹1 天前
数据结构 ——— 八大排序算法的思想及其实现
c语言·数据结构·排序算法·归并排序·希尔排序·快速排序·计数排序