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

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

代码:

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;
}
相关推荐
袋鼠云数栈6 小时前
集团数字化统战实战:统一数据门户与全业态监管体系构建
大数据·数据结构·人工智能·多模态
小月球~6 小时前
天梯赛 · 并查集
数据结构·算法
三道渊8 小时前
C语言:文件I/O
c语言·开发语言·数据结构·c++
kali-Myon9 小时前
CTFshow-Pwn142-Off-by-One(堆块重叠)
c语言·数据结构·安全·gdb·pwn·ctf·
计算机安禾9 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
XiYang-DING10 小时前
【LeetCode】链表 + 快慢指针找中间 | 2095. 删除链表的中间节点
算法·leetcode·链表
Zarek枫煜10 小时前
[特殊字符] C3语言:传承C之高效,突破C之局限
c语言·开发语言·c++·单片机·嵌入式硬件·物联网·算法
寻寻觅觅☆10 小时前
东华OJ-基础题-30-求最晚和最早日期(C++)
数据结构·c++·算法
爱编码的小八嘎11 小时前
C语言完美演绎6-11
c语言
星辰徐哥12 小时前
C语言网络编程:TCP/IP协议栈、套接字、服务器/客户端通信深度解析
c语言·网络·tcp/ip