题目:
给你两个 非空 的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储 一位 数字。
请你将两个数相加,并以相同形式返回一个表示和的链表。
你可以假设除了数字 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
}