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
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章