美文网首页
leetcode - 2. 两数相加[Swift]

leetcode - 2. 两数相加[Swift]

作者: Kegem | 来源:发表于2022-04-18 15:18 被阅读0次
    题目描述

    给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
    请你将两个数相加,并以相同形式返回一个表示和的链表。
    你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

    示例 1:

    输入:l1 = [2,4,3], l2 = [5,6,4]
    输出:[7,0,8]
    解释:342 + 465 = 807

    示例 2:

    输入:l1 = [0], l2 = [0]
    输出:[0]

    示例 3:

    输入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
    输出:[8,9,9,9,0,0,0,1]

    提示:

    • 每个链表中的节点数在范围 [1, 100] 内
    • 0 <= Node.val <= 9
    • 题目数据保证列表表示的数字不含前导零
    解题思路

    其实这里没多么复杂的逻辑在里面,就是两个链表同一位位置的数值相加即可,但是这里需要考虑进位的问题,也就是说该位置下值的和还需要加上进位的值,才是当前位置下的值的和sum = l1.value + l2.value + 进位的值,那么对应新链表同一位置下的值就是sum % 10,取余的原因就是大于10要进位,题目中说了,每个节点只能存储一位数字,那么下一个进位的值就是carry = sum / 10。根据这个思路下面给出代码。

    解题代码
    class ListNode {
        var val: Int = 0
        var next: ListNode? = nil
        
        init() {
            self.val = 0
            self.next = nil
        }
        
        init(_ val: Int) {
            self.val = val
            self.next = nil
        }
        
        init(_ val: Int, _ next: ListNode?) {
            self.val = val
            self.next = next
        }
        
    }
    
    
    struct Leetcode2 {
        func addTwoNumbers(_ l1: ListNode?, _ l2: ListNode?) -> ListNode? {
            // leetcode上给的函数不支持改动,故这里需要重新赋值
            var node1 = l1
            var node2 = l2
            // 新链表的表头,也是最后返回的值
            var newNode: ListNode?
            // 新链表的表尾
            var tailNode: ListNode?
            // 进位
            var carry: Int = 0
            // 循环链表
            while node1 != nil || node2 != nil {
                // 取出l1的值,当不存在该节点时,补0
                let l1Value = node1?.val ?? 0
                // 取出l2的值,当不存在该节点时,补0
                let l2Value = node2?.val ?? 0
                // 计算两值之和 + 进位的值 = 该节点的最终的和值
                let sum = l1Value + l2Value + carry
                // 确定新链表表头
                if newNode == nil {
                    newNode = ListNode(sum % 10)
                    // 这是是第一个节点 故表头和表尾是同一个节点
                    tailNode = newNode
                } else {
                    // 当新的链表已经存在时,当前的尾部节点的next就是新的节点
                    tailNode?.next = ListNode(sum % 10)
                    // 更新尾节点
                    tailNode = tailNode?.next
                }
                // 下一个节点的进位
                carry = sum / 10
                // 记录l1的下一个节点
                if node1 != nil {
                    node1 = node1?.next
                }
                // 记录l2的下一个节点
                if node2 != nil {
                    node2 = node2?.next
                }
            }
            // 当最后的进位>0时,需要增加节点
            if carry > 0 {
                tailNode?.next =  ListNode(carry)
                tailNode = tailNode?.next
            }
            return newNode
        }
    }
    

    原题链接https://leetcode-cn.com/problems/add-two-numbers

    相关文章

      网友评论

          本文标题:leetcode - 2. 两数相加[Swift]

          本文链接:https://www.haomeiwen.com/subject/ufydertx.html