合并两个有序链表算法(leetcode第21题)

题目描述:

复制代码
将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 

示例 1:

复制代码
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]
示例 2:

输入:l1 = [], l2 = []
输出:[]
示例 3:

输入:l1 = [], l2 = [0]
输出:[0]
 

提示:

两个链表的节点数目范围是 [0, 50]
-100 <= Node.val <= 100
l1 和 l2 均按 非递减顺序 排列

算法一:

思路:

使用指针法,创建新链表,逐个存入新链表

代码实现:
cpp 复制代码
# include<stdlib.h>

struct ListNode{
    int val;
    struct ListNode *next;
};

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){
    struct ListNode *newhead=(struct ListNode*)malloc(sizeof(struct ListNode));//新链表
    struct ListNode *prev=newhead;//节点指针
    while(list1!=NULL && list2!=NULL){//都不为空节点
        if(list1->val < list2->val){//list1小
            prev->next=list1;//入新链表
            list1=list1->next;//list1后移
        }
        else{//list2
            prev->next=list2;
            list2=list2->next;
        }
        prev=prev->next;//节点指针后移
    }
    prev->next=list1==NULL?list2:list1;//取另一个非空的链表节点
    return newhead->next;//返回头节点指针
}

算法二:

思路:

使用递归法,逐步缩小链表规模

判断链表节点指向值大小,小的节点指针后移,进行递归,最终合并完成

代码实现:
cpp 复制代码
# include<stdlib.h>

struct ListNode{
    int val;
    struct ListNode *next;
};

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2){
    if(list1==NULL){//list1为空节点
        return list2;//返回list2
    }
    else if(list2==NULL){//list2为空节点
        return list1;//返回list1
    }
    else if(list1->val < list2->val){//list1指向的值更小
        list1->next=mergeTwoLists(list1->next,list2);//list1->next递归
        return list1;//返回list1
    }
    else{//list2指向的值更小
        list2->next=mergeTwoLists(list1,list2->next);//list2->next递归
        return list2;//返回list2
    }
}
相关推荐
Live&&learn3 分钟前
算法训练-数据结构
数据结构·算法·leetcode
松岛雾奈.2301 小时前
机器学习--PCA降维算法
人工智能·算法·机器学习
电子_咸鱼2 小时前
【STL string 全解析:接口详解、测试实战与模拟实现】
开发语言·c++·vscode·python·算法·leetcode
sweet丶2 小时前
适合iOS开发的一种缓存策略YYCache库 的原理
算法·架构
是宇写的啊2 小时前
算法—滑动窗口
算法
风筝在晴天搁浅2 小时前
代码随想录 509.斐波那契数
数据结构·算法
落落落sss3 小时前
java实现排序
java·数据结构·算法
limenga1023 小时前
支持向量机(SVM)深度解析:理解最大间隔原理
算法·机器学习·支持向量机
coder江4 小时前
二分查找刷题总结
算法
坚持就完事了5 小时前
蓝桥杯中Python常用的库与模块
python·算法