21. 合并两个有序链表 --力扣 --JAVA

题目

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

解题思路

  1. 判断特殊情况,如:两个列表中其中一个为空;
  2. 创建一个初始节点用于返回;
  3. 通过while循环来逐个遍历链表,并对比节点值;
  4. 将为遍历完的链表直接赋值给记录节点(因为链表当前节点包含下一个节点的信息,所以不需要逐个遍历来进行赋值);

代码展示

java 复制代码
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        if(list1 == null){
            return list2;
        }
        if(list2 == null){
            return list1;
        }
        ListNode ans = null;
        if(list1.val <= list2.val){
            ans = list1;
            list1 = list1.next;
        } else {
            ans = list2;
            list2 = list2.next;
        }
        //记录节点
        ListNode nex = ans;
        while (list1 != null && list2 != null){
            if(list1.val <= list2.val){
                nex.next = list1;
                list1 = list1.next;
            } else {
                nex.next = list2;
                list2 = list2.next;
            }
            nex = nex.next;
        }
        if(list1 == null){
            nex.next = list2;
        } else {
            nex.next = list1;
        }
        return ans;
    }
}
相关推荐
君义_noip4 分钟前
信息学奥赛一本通 2134:【25CSPS提高组】道路修复 | 洛谷 P14362 [CSP-S 2025] 道路修复
c++·算法·图论·信息学奥赛·csp-s
kaikaile199516 分钟前
基于拥挤距离的多目标粒子群优化算法(MO-PSO-CD)详解
数据结构·算法
不忘不弃27 分钟前
求两组数的平均值
数据结构·算法
leaves falling28 分钟前
迭代实现 斐波那契数列
数据结构·算法
珂朵莉MM39 分钟前
全球校园人工智能算法精英大赛-产业命题赛-算法巅峰赛 2025年度画像
java·人工智能·算法·机器人
Morwit1 小时前
*【力扣hot100】 647. 回文子串
c++·算法·leetcode
DonnyCoy1 小时前
Android性能之数据结构
数据结构
天赐学c语言1 小时前
1.7 - 删除排序链表中的重要元素II && 哈希冲突常用解决冲突方法
数据结构·c++·链表·哈希算法·leecode
tobias.b1 小时前
408真题解析-2009-13-计组-浮点数加减运算
算法·计算机考研·408考研·408真题
菜鸟233号2 小时前
力扣96 不同的二叉搜索树 java实现
java·数据结构·算法·leetcode