-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.go
110 lines (90 loc) · 1.38 KB
/
run.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
package numbers
import (
"fmt"
)
/**
* Definition for singly-linked list.
* type ListNode struct {
* Val int
* Next *ListNode
* }
*/
// ListNode 存储
type ListNode struct {
Val int
Next *ListNode
}
func addTwoNumbers(l1 *ListNode, l2 *ListNode) *ListNode {
r := new(ListNode)
temp, old := r, 0
for {
l1 = nonil(l1)
l2 = nonil(l2)
n := l1.Val + l2.Val + old
if n > 9 {
n -= 10
old = 1
} else {
old = 0
}
temp.Val = n
// 准备下一个
l1 = next(l1)
l2 = next(l2)
if l1 == nil && l2 == nil {
break
}
// 下一节点
temp.Next = new(ListNode)
temp = temp.Next
}
if old == 1 {
temp.Next = &ListNode{Val: old}
}
return r
}
// 下一个节点
func next(ln *ListNode) *ListNode {
if ln != nil {
return ln.Next
}
return nil
}
// 节点不能为nil
func nonil(ln *ListNode) *ListNode {
if ln != nil {
return ln
}
return &ListNode{Val: 0}
}
// 生成ListNode
func makeListNode(s []int) *ListNode {
if len(s) == 0 {
return nil
}
ln := new(ListNode)
ln.Val = s[0]
temp := ln
for i := 1; i < len(s); i++ {
temp.Next = &ListNode{Val: s[i]}
temp = temp.Next
}
return ln
}
// 打印ListNode
func printLN(ln *ListNode) {
if ln == nil {
return
}
i := 1
for {
fmt.Printf("%d:%d\n", i, ln.Val)
fmt.Printf("%d:%+v\n", i, ln.Next)
if ln.Next != nil {
ln = ln.Next
i++
} else {
break
}
}
}