合并两个升序链表,合并后也是升序的

开始时也要判断是否有一个链表本来就是空,如果是,直接返回另外一个链表

代码:

c 复制代码
struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){
    if(list1==NULL)
    {
        return list2;
    }

     if(list2==NULL)
    {
        return list1;
    }
struct ListNode* cur1=list1;
struct ListNode* cur2=list2;
struct ListNode* newnode=NULL;
struct ListNode* tail=NULL;
while(cur1&&cur2)
{
    if(cur1->val<=cur2->val)
    {
        if(tail==NULL)
        {
            newnode=tail=cur1;
        }else
        {
            tail->next=cur1;
            tail=tail->next;
        }
        cur1=cur1->next;
    }else
    {
         if(tail==NULL)
        {
            newnode=tail=cur2;
        }else
        {
            tail->next=cur2;
            tail=tail->next;

        }
        cur2=cur2->next;
    }
}
if(cur1)
{
    tail->next=cur1;
}
if(cur2)
{
    tail->next=cur2;
}
return newnode;
}
相关推荐
SystickInt15 分钟前
C语言 strcpy和memcpy 异同/区别
c语言·开发语言
CS Beginner26 分钟前
【C语言】windows下编译mingw版本的glew库
c语言·开发语言·windows
JAY_LIN——834 分钟前
指针-数组
c语言·排序算法
进阶的猪2 小时前
STM32 使用HAL库SPI读写FLASH(W25Q128JV)数据 Q&A
c语言·stm32·单片机
charlie1145141913 小时前
现代C++嵌入式教程:C++98基础特性:从C到C++的演进(1)
c语言·开发语言·c++·笔记·学习·教程
菜鸟233号5 小时前
力扣669 修剪二叉搜索树 java实现
java·数据结构·算法·leetcode
CQ_YM6 小时前
Linux管道通信
linux·c语言·管道·ipc·管道通信
SadSunset6 小时前
力扣题目142. 环形链表 II的解法分享,附图解
算法·leetcode·链表
Sunsets_Red6 小时前
2025 FZYZ夏令营游记
java·c语言·c++·python·算法·c#
jingfeng5148 小时前
哈希表的概念+实现
数据结构·哈希算法·散列表