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

点赞收藏和关注!!!

谢谢大家!!!

相关推荐
梭七y5 小时前
【力扣hot100题】(103)移动零
数据结构·算法·leetcode
H CHY6 小时前
C++代码
c语言·开发语言·数据结构·c++·算法·青少年编程
xiaolang_8616_wjl6 小时前
c++题目_传桶(改编于atcoder(题目:Heavy Buckets))
数据结构·c++·算法
历程里程碑8 小时前
双指针巧解LeetCode接雨水难题
java·开发语言·数据结构·c++·python·flask·排序算法
橘颂TA9 小时前
【剑斩OFFER】算法的暴力美学——链表相加(二)
数据结构·链表·牛客·结构与算法
报错小能手9 小时前
数据结构 可扩展哈希
数据结构·哈希算法·散列表
AI科技星10 小时前
宇宙的像素:真空中一点如何编码无限星光
数据结构·人工智能·算法·机器学习·重构
王璐WL10 小时前
【数据结构】二叉树经典算法题和选择题
数据结构·算法
jllllyuz10 小时前
MATLAB多目标优化:SQP算法实现
数据结构·算法·matlab
im_AMBER10 小时前
数据结构 14 【复习】二叉树中序遍历 | 线索二叉树 | 树、森林、二叉树的转换 | 层次遍历二叉树
数据结构·笔记·学习·算法