合并两个有序链表算法(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
    }
}
相关推荐
科研前沿30 分钟前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨31 分钟前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月1 小时前
map与unordered_map区别
算法·哈希算法
图码1 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
handler012 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
minglie12 小时前
实数列的常用递推模式
算法
代码小书生2 小时前
math,一个基础的 Python 库!
人工智能·python·算法
AI科技星2 小时前
全域数学·数术本源·高维代数卷(72分册)【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算
生成论实验室2 小时前
《事件关系阴阳博弈动力学:识势应势之道》第一篇:生成正在发生——从《即事经》到事件-关系网络
人工智能·科技·算法·架构·创业创新
漂流瓶jz2 小时前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva