2.go 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. package main
  2. import (
  3. "fmt"
  4. )
  5. type ListNode struct {
  6. Val int
  7. Next *ListNode
  8. }
  9. func list2str(head *ListNode) string {
  10. curr := head
  11. str := make([]rune, 0)
  12. for curr != nil {
  13. str = append(str, rune(curr.Val+'0'))
  14. curr = curr.Next
  15. }
  16. return string(str)
  17. }
  18. /**
  19. * Definition for singly-linked list.
  20. * type ListNode struct {
  21. * Val int
  22. * Next *ListNode
  23. * }
  24. */
  25. // (3->2->1) + (2->1) = (5->3->1), 123 + 12 = 135
  26. func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
  27. // get head of result list
  28. head := &ListNode{(l1.Val + l2.Val) % 10, nil}
  29. remain := int((l1.Val + l2.Val) / 10)
  30. curr := head
  31. l1 = l1.Next
  32. l2 = l2.Next
  33. // while l1 != [] and l2 != [], calculate l1 + l2
  34. for l1 != nil && l2 != nil {
  35. curr.Next = &ListNode{(l1.Val + l2.Val + remain) % 10, nil}
  36. remain = int((l1.Val + l2.Val + remain) / 10)
  37. curr = curr.Next
  38. l1 = l1.Next
  39. l2 = l2.Next
  40. }
  41. // l1 / l2 is nil (l1 == nil, l2 == nil, do nothing)
  42. if l1 != nil {
  43. curr.Next = &ListNode{(l1.Val + remain) % 10, l1.Next}
  44. remain = int((l1.Val + remain) / 10)
  45. curr = curr.Next
  46. } else if l2 != nil {
  47. curr.Next = &ListNode{(l2.Val + remain) % 10, l2.Next}
  48. remain = int((l2.Val + remain) / 10)
  49. curr = curr.Next
  50. }
  51. // add remainder
  52. for remain != 0 {
  53. if curr.Next != nil {
  54. curr.Next.Val += remain
  55. remain = int(curr.Next.Val / 10)
  56. curr.Next.Val %= 10
  57. curr = curr.Next
  58. } else {
  59. curr.Next = &ListNode{remain, nil}
  60. remain = 0
  61. }
  62. }
  63. return head
  64. }
  65. func list2int(head *ListNode) int64 {
  66. beg := head
  67. res := int64(0)
  68. for i := 1; beg != nil; i *= 10 {
  69. res += int64(beg.Val * i)
  70. beg = beg.Next
  71. }
  72. return res
  73. }
  74. func int2list(num int64) *ListNode {
  75. head := &ListNode{int(num % 10), nil}
  76. num /= 10
  77. for tail := head; num != 0; num /= 10 {
  78. tail.Next = &ListNode{int(num % 10), nil}
  79. tail = tail.Next
  80. }
  81. return head
  82. }
  83. // will overflow
  84. func addTwoNumbersOld(l1 *ListNode, l2 *ListNode) *ListNode {
  85. return int2list(list2int(l1) + list2int(l2))
  86. }
  87. func main() {
  88. l13 := ListNode{3, nil}
  89. l12 := ListNode{2, &l13}
  90. l1 := &ListNode{1, &l12}
  91. l23 := ListNode{9, nil}
  92. l22 := ListNode{9, &l23}
  93. l2 := &ListNode{1, &l22}
  94. fmt.Println(list2str(addTwoNumbers(l1, l2)))
  95. }