博客
关于我
No.021:Merge Two Sorted Lists
阅读量:438 次
发布时间:2019-03-06

本文共 1735 字,大约阅读时间需要 5 分钟。

合并两个已排序的链表是一个常见的问题,目标是将两个链表拼接成一个新的链表,并返回其第一个节点。本文将详细介绍如何实现这一过程。

输入节点情况

首先,我们需要考虑输入链表可能存在null的情况。具体来说:

  • 如果其中一个链表为空,直接返回另一个链表的头节点。
  • 如果两个链表都为空,则返回null。
  • 节点定义

    节点的定义如下:

    class ListNode {    public int val;    public ListNode next;    public ListNode prev;}

    实现步骤

  • 初始化变量

    • 创建一个新的链表来保存结果。
    • 使用一个指针记录上一个节点,用于拼接新的链表。
    • 确定第一个节点,确保较小的节点作为基准链表。
  • 比较节点值

    • 比较当前两个链表的节点值,决定哪个作为基准链表。
    • 交换两个链表的位置,确保基准链表始终指向较小的节点。
  • 遍历链表

    • 将当前基准链表的节点连接到上一个节点的后面。
    • 更新上一个节点指针。
    • 移动基准链表指针到下一个节点,继续比较和拼接。
  • 处理剩余节点

    • 当其中一个链表遍历完毕时,将剩下的另一条链表连接到结果链表的末尾。
  • 返回结果

    • 返回结果链表的第一个节点。
  • 代码实现

    public class ListNode {    public int val;    public ListNode next;    public ListNode prev;    public ListNode(int val) {        this.val = val;    }}public class Solution {    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {        // 处理空链表情况        if (l1 == null) {            return l2;        }        if (l2 == null) {            return l1;        }        // 初始化结果链表        ListNode result = new ListNode(0);        ListNode last = result;        // 确定第一个节点        if (l1.val > l2.val) {            // 交换l1和l2的位置            ListNode temp = l1;            l1 = l2;            l2 = temp;        }        // 开始遍历并拼接        while (true) {            // 将当前l1节点连接到结果链表            last.next = l1;            last = last.next;            // 移动l1指针到下一个节点            if (l1.next == null) {                // 当l1遍历完毕,将l2拼接到结果链表                l1.next = l2;                break;            }            l1 = l1.next;            // 比较当前节点的值,并交换位置            if (l1.val > l2.val) {                // 交换l1和l2的位置                ListNode temp = l2;                l2 = l1;                l1 = temp;            }        }        return result.next;    }}

    总结

    该算法通过交换节点的位置和逐步拼接的方式,确保了两个链表合并后的链表是有序的。代码结构清晰,逻辑简单易懂,适合处理各种边界情况。

    转载地址:http://soyyz.baihongyu.com/

    你可能感兴趣的文章
    oracle Extract 函数
    查看>>
    uni-app开发环境自动部署的一个误区(App running at...)
    查看>>
    Oracle GoldenGate Director安装和配置(无图)
    查看>>
    oracle instr函数详解
    查看>>
    Oracle Java所有版本的下载链接
    查看>>
    oracle ogg 单实例双向复制搭建(oracle-oracle)--Oracle GoldenGate
    查看>>
    oracle ORA-14402 OGG-01296
    查看>>
    oracle partition by list,深入解析partition-list 分区
    查看>>
    Oracle PL/SQL Dev工具(破解版)被植入勒索病毒的安全预警及自查通告
    查看>>
    oracle rac集群的东西之QQ聊天
    查看>>
    oracle scott趣事
    查看>>
    oracle script
    查看>>
    Oracle select表要带双引号的原因
    查看>>
    Oracle SOA Suit Adapter
    查看>>
    Oracle Spatial GeoRaster 金字塔栅格存储
    查看>>
    Oracle spatial 周边查询SQL
    查看>>
    Oracle Spatial空间数据库建立
    查看>>
    UML— 活动图
    查看>>
    oracle sqlplus已停止工作,安装完成客户端后sqlplus报“段错误”
    查看>>
    oracle SQLserver 函数
    查看>>