【百日算法计划】:每日一题,见证成长(010)

题目

合并两个排序的链表

输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的

示例1:

输入:1->2->4, 1->3->4

输出:1->1->2->3->4->4

思路

引入一个带虚拟头结点和tail指针的结果链表,把原节点的值比较大小后加入到结果链表中。

java 复制代码
 public ListNode mergeTwoLists(ListNode l1, ListNode l2) {

    if (l1 == null) return l2;
    if (l2 == null) return l1;

    ListNode p1 = l1;
    ListNode p2 = l2;

    //创建一个新链表,用于存放排序好的链表
    ListNode resultNode = new ListNode();
    ListNode tail = resultNode;//尾指针

    while (p1 != null && p2 != null){
        if (p1.val <= p2.val){
            tail.next = p1;
            tail = p1;
            p1 = p1.next;
        } else {
            tail.next = p2;
            tail = p2;
            p2 = p2.next;
        }
    }
    if (p1 != null) tail.next = p1;
    if (p2 != null) tail.next = p2;
    return resultNode.next;
 }
相关推荐
Nobkins9 分钟前
2023CCPC河南省赛暨河南邀请赛个人补题ABEFGHK
开发语言·数据结构·c++·算法·图论
王RuaRua13 分钟前
[数据结构]7. 堆-Heap
c语言·数据结构·算法·链表
朱剑君1 小时前
第八天——贪心算法——队列重构问题
算法·贪心算法·重构
仙人掌_lz1 小时前
深度理解用于多智能体强化学习的单调价值函数分解QMIX算法:基于python从零实现
python·算法·强化学习·rl·价值函数
riri19191 小时前
算法分析:蛮力法
数据结构·算法
Christo31 小时前
关于在深度聚类中Representation Collapse现象
人工智能·深度学习·算法·机器学习·数据挖掘·embedding·聚类
摄殓永恒1 小时前
猫咪几岁
数据结构·c++·算法
机器学习之心1 小时前
分类预测 | Matlab实现ABC-Transformer人工蜂群算法优化编码器多特征分类预测/故障诊断Matlab实现
算法·matlab·分类
oioihoii1 小时前
C++23 新增的查找算法详解:ranges::find_last 系列函数
java·算法·c++23
MoonBit月兔2 小时前
插件双更新:LeetCode 刷题支持正式上线,JetBrains IDE 插件持续升级!
ide·算法·leetcode