-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmain.go
141 lines (119 loc) · 2.19 KB
/
main.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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
package main
import (
"bufio"
"io"
aoc "github.com/teivah/advent-of-code"
)
func fs1(input io.Reader) int {
scanner := bufio.NewScanner(input)
res := 0
for scanner.Scan() {
s := scanner.Text()
del := aoc.NewDelimiter(s, " ")
v := getResult1(del.GetInts())
res += v
}
return res
}
func getResult1(numbers []int) int {
var lines [][]int
lines = append(lines, numbers)
cur := numbers
for {
var next []int
allZero := true
for i := 0; i < len(cur)-1; i++ {
diff := cur[i+1] - cur[i]
if diff != 0 {
allZero = false
}
next = append(next, diff)
}
lines = append(lines, next)
if allZero {
break
}
cur = next
}
lines[len(lines)-1] = append(lines[len(lines)-1], 0)
for i := len(lines) - 2; i >= 0; i-- {
sum := lines[i+1][len(lines[i+1])-1] + lines[i][len(lines[i])-1]
lines[i] = append(lines[i], sum)
}
return lines[0][len(lines[0])-1]
}
func fs2(input io.Reader) int {
scanner := bufio.NewScanner(input)
res := 0
for scanner.Scan() {
s := scanner.Text()
del := aoc.NewDelimiter(s, " ")
v := getResult2(del.GetInts())
res += v
}
return res
}
type Node struct {
value int
previous *Node
next *Node
}
func getResult2(numbers []int) int {
var lines []*Node
lines = append(lines, toNodes(numbers))
cur := lines[0]
for {
var head *Node
var curNode *Node
allZero := true
for cur.next != nil {
diff := cur.value - cur.next.value
if diff != 0 {
allZero = false
}
n := &Node{
value: diff,
}
if head == nil {
head = n
curNode = n
} else {
curNode.next = n
curNode = n
}
cur = cur.next
}
lines = append(lines, head)
if allZero {
break
}
cur = head
}
lines[len(lines)-1].previous = &Node{
value: 0,
}
lines[len(lines)-1] = lines[len(lines)-1].previous
for i := len(lines) - 2; i >= 0; i-- {
sum := lines[i].value + lines[i+1].value
lines[i].previous = &Node{
value: sum,
}
lines[i] = lines[i].previous
}
return lines[0].value
}
func toNodes(numbers []int) *Node {
head := &Node{
value: numbers[0],
}
cur := head
for i := 1; i < len(numbers); i++ {
n := &Node{
value: numbers[i],
previous: cur,
}
cur.next = n
cur = n
}
return head
}