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

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

代码:

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;
}
相关推荐
叶宇燚29 分钟前
Java整理--数据结构篇
java·开发语言·数据结构
晚枫歌F34 分钟前
btree B树实现key-value存储
开发语言·数据结构
wangchen_037 分钟前
B树、B+树详解
数据结构·b树·哈希算法
炸膛坦客40 分钟前
单片机/C语言八股:(七)C 程序运行时内存布局的动态变化
c语言·开发语言
无尽的罚坐人生1 小时前
hot 100 101. 对称二叉树
数据结构·算法·leetcode
ZCollapsar.1 小时前
C++从入门到入土 (5):.C/C++内存管理
c语言·c++·学习
一叶落4381 小时前
【LeetCode】1. 两数之和(Two Sum)— 哈希表经典题解(C语言)
数据结构·c++·算法·leetcode
m0_672703312 小时前
上机练习第43天
数据结构·算法
菜菜小狗的学习笔记2 小时前
数据结构(二)队列和栈
数据结构
不想看见4042 小时前
Add Strings数字处理--力扣101算法题解笔记
数据结构·算法·leetcode