mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-06 01:15:57 +08:00
Merge pull request #167 from novahe/master
fix/445: add other solutions
This commit is contained in:
@ -67,3 +67,72 @@ func getLength(l *ListNode) int {
|
||||
}
|
||||
return count
|
||||
}
|
||||
|
||||
func addTwoNumbers1(l1 *ListNode, l2 *ListNode) *ListNode {
|
||||
reservedL1 := reverseList(l1)
|
||||
reservedL2 := reverseList(l2)
|
||||
|
||||
dummyHead := &ListNode{}
|
||||
head := dummyHead
|
||||
carry := 0
|
||||
for reservedL1 != nil || reservedL2 != nil || carry > 0 {
|
||||
val := carry
|
||||
if reservedL1 != nil {
|
||||
val = reservedL1.Val + val
|
||||
reservedL1 = reservedL1.Next
|
||||
}
|
||||
if reservedL2 != nil {
|
||||
val = reservedL2.Val + val
|
||||
reservedL2 = reservedL2.Next
|
||||
}
|
||||
carry = val / 10
|
||||
head.Next = &ListNode{Val: val % 10}
|
||||
head = head.Next
|
||||
}
|
||||
return reverseList(dummyHead.Next)
|
||||
}
|
||||
|
||||
func reverseList(head *ListNode) *ListNode {
|
||||
var prev *ListNode
|
||||
for head != nil {
|
||||
tmp := head.Next
|
||||
head.Next = prev
|
||||
|
||||
prev = head
|
||||
head = tmp
|
||||
}
|
||||
return prev
|
||||
}
|
||||
|
||||
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
|
||||
stack1 := pushStack(l1)
|
||||
stack2 := pushStack(l2)
|
||||
|
||||
dummyHead := &ListNode{}
|
||||
head := dummyHead
|
||||
carry := 0
|
||||
for len(stack1) > 0 || len(stack2) > 0 || carry > 0 {
|
||||
val := carry
|
||||
if len(stack1) > 0 {
|
||||
val = val + stack1[len(stack1)-1]
|
||||
stack1 = stack1[:len(stack1)-1]
|
||||
}
|
||||
if len(stack2) > 0 {
|
||||
val = val + stack2[len(stack2)-1]
|
||||
stack2 = stack2[:len(stack2)-1]
|
||||
}
|
||||
carry = val / 10
|
||||
tmp := head.Next
|
||||
head.Next = &ListNode{Val: val % 10, Next: tmp}
|
||||
}
|
||||
return dummyHead.Next
|
||||
}
|
||||
|
||||
func pushStack(l *ListNode) []int {
|
||||
var stack []int
|
||||
for l != nil {
|
||||
stack = append(stack, l.Val)
|
||||
l = l.Next
|
||||
}
|
||||
return stack
|
||||
}
|
||||
|
Reference in New Issue
Block a user