[leetcode in golang]21、合并两个有序链表

反骨奇兵 · · 994 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

链表分为带哨兵节点和不带哨兵节点。
加入哨兵节点有四个使用场景:
1、创建链表,需要考虑链表为空的情况。
2、遍历链表。
3、特定位置删除/插入节点,判断链表是否为空并且进行操作的节点的前一个节点的状态。

/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func mergeTwoLists(l1 *ListNode, l2 *ListNode) *ListNode {
    if l1==nil{
        return l2
    }
    if l2==nil{
        return l1
    }
    if l1.Val<=l2.Val{
        l1.Next=mergeTwoLists(l1.Next,l2)
        return l1
    }else{
        l2.Next=mergeTwoLists(l1,l2.Next)
        return l2
    }
}

进行递归,没有新建一个链表存储排序后的元素,而是直接返回两链表中具有最小值的链表。


有疑问加站长微信联系(非本文作者)

本文来自:简书

感谢作者:反骨奇兵

查看原文:[leetcode in golang]21、合并两个有序链表

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

994 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传