力扣热题100------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 均按 非递减顺序 排列

思路:我们先创建一个新结点 创建一个指针 使它指向新结点 使用一个while循环 来判断两个链表是否为空 如果两个链表都为空的话 我们来计算两个链表的结点谁比较大 我们让新结点指向较小的数 如果有一个链表为空的话 那我们就让新结点直接指向另一个链表的结点

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        ListNode dummy = new ListNode(-1);
        ListNode current = dummy;
        while (list1!=null && list2!=null){
            if (list1.val>=list2.val){
                current.next=list2;
                list2=list2.next;
            }else {
                current.next=list1;
                list1=list1.next;
            }
            current=current.next;
        }
        if (list1!=null){
            current.next=list1;
        }else{
            current.next=list2;
        }
        return dummy.next;
    }
}
相关推荐
旖-旎7 分钟前
哈希表(存在重复元素||)(4)
数据结构·c++·算法·leetcode·哈希算法·散列表
Run_Teenage10 分钟前
Linux:认识信号,理解信号的产生和处理
linux·运维·算法
無限進步D25 分钟前
蓝桥杯赛前刷题
c++·算法·蓝桥杯·竞赛
CoderCodingNo27 分钟前
【GESP】C++二级真题 luogu-B4497, [GESP202603 二级] 数数
开发语言·c++·算法
磊 子30 分钟前
八大排序之冒泡排序+选择排序
数据结构·算法·排序算法
_深海凉_30 分钟前
LeetCode热题100-买卖股票的最佳时机
leetcode
We་ct31 分钟前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
潇洒畅想35 分钟前
1.1 从∑到∫:用循环理解求和与累积
java·数据结构·python·算法
郝学胜-神的一滴1 小时前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
ZC跨境爬虫1 小时前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json