【Golang】LeetCode 21. 合并两个有序链表

21. 合并两个有序链表

题目描述

思路

解决这道题我们使用一个常见的思路,那就是设立一个哑节点dummyNode。在解 LeetCode Hot 100 链表部分的题目时,我们经常需要建立哑节点,并让哑节点的值为空,它的Next指向真正的链表当中的节点。这样,才完成对链表的处理之后,返回dummyNode.Next就是我们想要的最终答案。

建立好哑节点之后,我们建立三个指针p, q, t := list1, list2, dummyNode,然后开始使用p, q对两个链表进行遍历。循环的条件是p != nil && q != nil,如果p.Val < q.Val,就意味着在答案所对应链表当中,当前的p节点应该排在当前的q节点前面。我们使用t来维护答案所在的链表,令t.Next = p,将当前节点插入到t节点之后当中。

反之,如果p.Val >= q.Val,则我们将当前的q插入到t之后。

节点插入之后,我们同时将p / q以及t向后移动一位,继续对两个链表进行遍历和比对。

当循环终止时,链表未必已经完全插入,因为其中某个链表可能很短,而另一个很长。但由于题目中已经显式地告诉了我们,两个链表是有序的,因此当前t节点所在的链表的最后一个节点(最大值)一定不比还没结束的链表当前的头节点的值更大。基于这条性质,我们将当前还没结束的链表的节点所对应的指针插入到t之后即可。

由于t是在对dummyNode进行维护,最终我们返回dummyNode.Next即位答案。

基于以上思路,我们来写代码解决问题。

Golang 代码

go 复制代码
/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func mergeTwoLists(list1 *ListNode, list2 *ListNode) *ListNode {
    dummyNode := new(ListNode)
    p, q, t := list1, list2, dummyNode
    for p != nil && q != nil {
        if p.Val < q.Val {
            t.Next = p
            p = p.Next
        } else {
            t.Next = q
            q = q.Next
        }
        t = t.Next
    }

    if p != nil {
        t.Next = p
    }
    if q != nil {
        t.Next = q
    }

    return dummyNode.Next
}
相关推荐
JCGKS16 小时前
海量文档单词计数算法方案分析
golang·数据结构与算法·海量数据·搜索引起·倒排查找
老鼠只爱大米17 小时前
LeetCode经典算法面试题 #347:前 K 个高频元素(最小堆、桶排序、快速选择等多种实现方案详解)
算法·leetcode·堆排序·java面试题·桶排序·快速选择·topk
liuyao_xianhui17 小时前
优选算法_分治_快速排序_归并排序_C++
开发语言·数据结构·c++·算法·leetcode·排序算法·动态规划
福大大架构师每日一题19 小时前
ollama v0.18.2 发布!OpenClaw 安装优化、Claude 加速、MLX 量化全面升级
golang·ollama
月落归舟19 小时前
每日算法题 14---14.环形链表
数据结构·算法·链表
sheeta199819 小时前
LeetCode 每日一题笔记 日期:2025.03.23 题目:1594.矩阵的最大非负积
笔记·leetcode·矩阵
灰色小旋风19 小时前
力扣22 括号生成(C++)
开发语言·数据结构·c++·算法·leetcode
闻哥20 小时前
MySQL InnoDB 缓存池(Buffer Pool)详解:原理、结构与链表管理
java·数据结构·数据库·mysql·链表·缓存·面试
圣保罗的大教堂20 小时前
leetcode 1594. 矩阵的最大非负积 中等
leetcode
重生之我是Java开发战士20 小时前
【广度优先搜索】队列:N叉树的层序遍历,二叉树的锯齿形层序遍历,二叉树的最大宽度,在每个树行中找最大值
数据结构·算法·leetcode·广度优先