C语言/数据结构——每日一题(合并两个有序链表)

一.前言

嗨嗨嗨,大家好久不见!今天我在LeetCode看到了一道单链表题:https://leetcode.cn/problems/merge-two-sorted-lists想着和大家分享一下,废话不多说,让我们开始今天的题目分享吧。

二.正文

1.1题目描述

1.2题目分析

我们还是可以通过创建新链表的方法来解题:

1.首先我们创建新的单链表:ListNode* phead和ListNode* ptail分别作为新链表的头节点和尾节点。

2.其次我们再创建两个指针分别遍历上下两个链表:l1与l2。

3.如果l1小于或等于l2,那么将l1插入到我们的新链表中,并让l1移到下一个节点。

反之,那l2将插入到我们的新链表中,并让l2移到下一个节点。

需要注意的是如果phead初始是NULL的话,不论初始l1和l2谁大谁小都要让phead和ptail等于它们与之相对应的头节点。

例如:如果此时l1小于或等于l2,且phead=NULL。那摩就让phead=ptail=l1。

同理,反之,phead=ptail=l2。

1.3代码实现

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
 typedef struct ListNode ListNode;
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2)
{
    if(list1==NULL)
        return list2;
    if(list2==NULL)
    return list1;
    ListNode* l1=list1;
    ListNode* l2=list2;
    ListNode* phead;
    ListNode* ptail;
    phead=ptail=NULL;
    while(l1!=NULL&&l2!=NULL)
    {
if((l1->val)<=(l2->val))
{
    if(phead==NULL)
    {
        phead=ptail=l1;
        l1=l1->next;
    }
    else
    {
        ptail->next=l1;
        ptail=ptail->next;
        l1=l1->next;
    }
}
else
{
    if(phead==NULL)
    {
        phead=ptail=l2;
        l2=l2->next;
    }
    else{
        ptail->next=l2;
        ptail=ptail->next;
        l2=l2->next;
    }
}
    }
    if(l1==NULL)
    ptail->next=l2;
    if(l2==NULL)
    ptail->next=l1;
    return phead;
}

值得注意的是:我们的while结束条件中有两种结束情况:l1=NULL或l2=NULL这两种情况。

当l1=NULL的时候说明l1链表中的元素已经全部插入到新链表中了了,但是l2中的元素还没有插入完,这时候就需要我们在最后让l2中没插入的数据直接插入到新链表后面。

同理,当l2=NULL的时候说明l2链表中的元素已经全部插入到新链表中了了,但是l1中的元素还没有插入完,这时候就需要我们在最后让l1中没插入的数据直接插入到新链表后面。

三.结言

今天的题目分享就到这了,同学们我们下期再见。

相关推荐
freshman_y5 小时前
一篇介绍C语言中二级指针和二维数组的文章
c语言·开发语言
weixin_413920616 小时前
LVGL仪表显示项目
c语言
gumichef7 小时前
算法的时间复杂度和空间复杂度
数据结构
小柯博客8 小时前
STM32MP2安全启动技术深度解析
c语言·c++·stm32·嵌入式硬件·安全·开源·github
cpp_25018 小时前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
爱编码的小八嘎8 小时前
C语言完美演绎9-1
c语言
꧁细听勿语情꧂8 小时前
合并两个有序表、判断链表的回文结构、相交链表、环的链表一和二
c语言·开发语言·数据结构·算法
大肥羊学校懒羊羊9 小时前
完数与盈数的计算题解
数据结构·c++·算法
气宇轩昂固执狂9 小时前
01-初识C语言
c语言·开发语言
我要升天!10 小时前
C语言连接 MySQL:libmysqlclient 获取方式详解
c语言·开发语言·数据库·mysql·adb