美文网首页
2.两数相加

2.两数相加

作者: 寂灭天骄小童鞋 | 来源:发表于2020-02-27 10:50 被阅读0次

https://leetcode-cn.com/problems/add-two-numbers/

func addTwoNumbers(_ l1: ListNode?, _ l2: ListNode?) -> ListNode? {
    //先定义一个虚拟头结点,真实头结点为dummyNode.next
    let dummyNode = ListNode(0)
    //当前节点
    var curNode = dummyNode
    var carry = 0
    var sum = 0
    var l1Node = l1
    var l2Node = l2
    
    while (l1Node != nil) || (l2Node != nil) {
        sum = (l1Node?.val ?? 0) + (l2Node?.val ?? 0) + carry
        carry = sum / 10
        curNode.next = ListNode(sum % 10)
        curNode = curNode.next!
        
        if l1Node != nil {
            l1Node = l1Node?.next
        }
        
        if l2Node != nil {
            l2Node = l2Node?.next
        }
    }
    
    if carry == 1 {
        curNode.next = ListNode(1)
    }
    
    return dummyNode.next
}

相关文章

  • 2. 两数相加

    给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,它们的每个节点只存储单个数字。将两数相加返回一个新的链表...

  • 2. 两数相加

  • 2. 两数相加

    一、题目原型: 给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,它们的每个节点只存储单个数字。将两数相加...

  • 2. 两数相加

    题目 解析 本题只需要遍历一下单链表,将单链表的值添加到StringBuilder对象后然后转化成数字进行运算再反...

  • 2.两数相加

    题目 思路1.记录返回结构体2.两个结构体的两位数相加,记录进位3.位移结构体,赋值代码

  • 2. 两数相加

    https://leetcode-cn.com/problems/add-two-numbers/descript...

  • 2. 两数相加

    补充:我们现在的这种第一个节点是头节点。所以要 root.next如果我的 不想用这种方式 会遇到这样的问题。

  • 2. 两数相加

    链接:https://leetcode-cn.com/problems/add-two-numbers/ 代码地址...

  • 2.两数相加

    给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只...

  • 2. 两数相加

    题目 分析 解题方案: 初等数学 我们使用变量来跟踪进位,并从包含最低有效位的表头开始模拟逐位相加的过程。 就像你...

网友评论

      本文标题:2.两数相加

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