力扣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

  • l1l2 均按 非递减顺序 排列

思路

简单的链表作为我的链表入门

题解

Go 复制代码
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func mergeTwoLists(list1 *ListNode, list2 *ListNode) *ListNode {
    dummy := ListNode{}
    cur := &dummy
    for list1 != nil && list2 != nil{
        if list1.Val < list2.Val{
            cur.Next = list1
            list1 = list1.Next
        } else {
            cur.Next = list2
            list2 = list2.Next
        }
        cur = cur.Next
    }
    if list1 != nil{
        cur.Next = list1
    } else {
        cur.Next = list2
    }
    return dummy.Next
}
相关推荐
独自破碎E17 小时前
【前缀和+哈希】LCR_011_连续数组
算法·哈希算法
一条大祥脚18 小时前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
m0_5613596718 小时前
基于C++的机器学习库开发
开发语言·c++·算法
星空露珠18 小时前
速算24点所有题库公式
开发语言·数据库·算法·游戏·lua
2401_8324027518 小时前
C++中的类型擦除技术
开发语言·c++·算法
努力学习的小廉18 小时前
我爱学算法之—— 递归回溯综合(二)
开发语言·算法
sheji526118 小时前
JSP基于信息安全的读书网站79f9s--程序+源码+数据库+调试部署+开发环境
java·开发语言·数据库·算法
2301_7634724618 小时前
C++网络编程(Boost.Asio)
开发语言·c++·算法
依依yyy18 小时前
沪深300指数收益率波动性分析与预测——基于ARMA-GARCH模型
人工智能·算法·机器学习
踩坑记录18 小时前
leetcode hot100 23. 合并 K 个升序链表 hard 分治 迭代
leetcode·链表