2. 两数相加

89 阅读1分钟

题目:
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。

请你将两个数相加,并以相同形式返回一个表示和的链表。

你可以假设除了数字 0 之外,这两个数都不会以 0 开头。

来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/ad… 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解法:

/**
 * Definition for singly-linked list.
 * type ListNode struct {
 *     Val int
 *     Next *ListNode
 * }
 */
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
    node1, node2 := l1, l2
    carry := 0
    sum := 0
    node1Pre := &ListNode{Next:node1}

    for node1 != nil && node2 != nil {
        sum = node1.Val + node2.Val + carry
        if sum >= 10 {
            carry = 1
            sum = sum % 10
        } else {
            carry = 0
        }
        node1.Val =sum

        node1 = node1.Next
        node2 = node2.Next
        node1Pre = node1Pre.Next
    }


    if node1 != nil {
        for node1 != nil {
            sum = node1.Val +  carry
            if sum >= 10 {
                carry = 1
                sum = sum % 10
            } else {
                carry = 0
            }
            node1.Val =sum
            node1 = node1.Next
            node1Pre = node1Pre.Next
        }
    } else if node2 != nil  {
        node1Pre.Next = node2
        for node2 != nil {
            sum = node2.Val +  carry
            if sum >= 10 {
                carry = 1
                sum = sum % 10
            } else {
                carry = 0
            }
            node2.Val = sum
            node2 = node2.Next
            node1Pre = node1Pre.Next
        }
    } 
    if carry != 0 {
        node1Pre.Next = &ListNode{Val: carry}
    }

    return l1
}