golang力扣leetcode 21.合并两个有序链表

简介: golang力扣leetcode 21.合并两个有序链表

题解

1:55才把git总结好,做个水题睡觉了,,愿星光不负赶路人吧,两种实现方式

代码

package main
type ListNode struct {
  Val  int
  Next *ListNode
}
func mergeTwoLists1(l1 *ListNode, l2 *ListNode) *ListNode {
  if l1 == nil {
    return l2
  }
  if l2 == nil {
    return l1
  }
  var head *ListNode
  if l1.Val > l2.Val {
    head = l2
    head.Next = mergeTwoLists(l1, l2.Next)
  } else {
    head = l1
    head.Next = mergeTwoLists(l1.Next, l2)
  }
  return head
}
func mergeTwoLists2(l1 *ListNode, l2 *ListNode) *ListNode {
  dummy := &ListNode{}
  head := dummy
  for l1 != nil && l2 != nil {
    if l1.Val < l2.Val {
      head.Next = l1
      l1 = l1.Next
    } else {
      head.Next = l2
      l2 = l2.Next
    }
    head = head.Next
  }
  if l1 != nil {
    head.Next = l1
    l1 = l1.Next
    head = head.Next
  } else if l2 != nil {
    head.Next = l2
    l2 = l2.Next
    head = head.Next
  }
  return dummy.Next
}
func main() {
}
目录
相关文章
|
1天前
|
Java
【LeetCode力扣】面试题 17.14. 最小K个数(top-k问题)
【LeetCode力扣】面试题 17.14. 最小K个数(top-k问题)
10 1
|
1天前
|
索引
每日一题:力扣328. 奇偶链表
每日一题:力扣328. 奇偶链表
13 4
|
1天前
|
存储 算法
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
【LeetCode力扣】单调栈解决Next Greater Number(下一个更大值)问题
6 0
|
1天前
leetcode代码记录(移除链表元素
leetcode代码记录(移除链表元素
10 0
【每日一题】LeetCode——反转链表
【每日一题】LeetCode——反转链表
【每日一题】LeetCode——链表的中间结点
【每日一题】LeetCode——链表的中间结点
|
1天前
|
C++
[leetcode 链表] 反转链表 vs 链表相交
[leetcode 链表] 反转链表 vs 链表相交
|
1天前
【力扣】148. 排序链表
【力扣】148. 排序链表
|
1天前
|
算法 C++
【刷题】Leetcode 1609.奇偶树
这道题是我目前做过最难的题,虽然没有一遍做出来,但是参考大佬的代码,慢慢啃的感觉的真的很好。刷题继续!!!!!!
8 0
|
1天前
|
算法 索引
【刷题】滑动窗口精通 — Leetcode 30. 串联所有单词的子串 | Leetcode 76. 最小覆盖子串
经过这两道题目的书写,相信大家一定深刻认识到了滑动窗口的使用方法!!! 下面请大家继续刷题吧!!!
11 0