leetcode 探索 鏈表 合併兩個有序鏈表

題目

將兩個升序鏈表合併爲一個新的 升序 鏈表並返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。
示例:

輸入:1->2->4, 1->3->4
輸出:1->1->2->3->4->4

來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/merge-two-sorted-lists

分析

新建一個頭節點,然後兩兩比較就好了,誰小誰鏈接上,只是需要判斷邊界條件。

解法

/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func mergeTwoLists(l1 *ListNode, l2 *ListNode) *ListNode {
    var head = &ListNode{}
    cur := head
    for cur != nil {
        if l2 == nil && l1 == nil {
            break
        } else if l1 == nil && l2 != nil {
            cur.Next = l2
            break
        } else if l2 == nil && l1 != nil {
            cur.Next = l1
            break
        } else if l1 != nil && l2 != nil {
            if l1.Val <= l2.Val {
                cur.Next = l1
                l1 = l1.Next
            } else {
                cur.Next = l2
                l2 = l2.Next
            }
        }
        cur = cur.Next
    }
    
    return head.Next
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章