-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmain.go
122 lines (107 loc) · 2.55 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
package main
import (
"bufio"
"io"
"strings"
lib "github.com/teivah/advent-of-code"
)
func fs1(input io.Reader) int {
scanner := bufio.NewScanner(input)
var claims []Claim
maxerRow := lib.NewMaxer()
maxerCol := lib.NewMaxer()
for scanner.Scan() {
claim := toClaim(scanner.Text())
claims = append(claims, claim)
maxerRow.Add(claim.nbInchesTop + claim.height)
maxerCol.Add(claim.nbInchesLeft + claim.width)
}
maxRow := maxerRow.Get()
maxCol := maxerCol.Get()
grid := make([][]int, maxRow)
for i := 0; i < maxRow; i++ {
grid[i] = make([]int, maxCol)
}
for _, claim := range claims {
for row := 0; row < claim.height; row++ {
for col := 0; col < claim.width; col++ {
grid[row+claim.nbInchesTop][col+claim.nbInchesLeft]++
}
}
}
count := 0
for i := 0; i < len(grid); i++ {
for j := 0; j < len(grid[0]); j++ {
v := grid[i][j]
if v > 1 {
count++
}
}
}
return count
}
type Claim struct {
nbInchesLeft int
nbInchesTop int
width int
height int
}
func toClaim(s string) Claim {
del := lib.NewDelimiter(s, " ")
tmp := del.GetString(2)
tmp = tmp[:len(tmp)-1]
inches := strings.Split(tmp, ",")
dims := strings.Split(del.GetString(3), "x")
return Claim{
nbInchesLeft: lib.StringToInt(inches[0]),
nbInchesTop: lib.StringToInt(inches[1]),
width: lib.StringToInt(dims[0]),
height: lib.StringToInt(dims[1]),
}
}
func fs2(input io.Reader) int {
scanner := bufio.NewScanner(input)
var claims []Claim
maxerRow := lib.NewMaxer()
maxerCol := lib.NewMaxer()
for scanner.Scan() {
claim := toClaim(scanner.Text())
claims = append(claims, claim)
maxerRow.Add(claim.nbInchesTop + claim.height)
maxerCol.Add(claim.nbInchesLeft + claim.width)
}
maxRow := maxerRow.Get()
maxCol := maxerCol.Get()
grid := make([][]map[int]struct{}, maxRow)
for i := 0; i < maxRow; i++ {
grid[i] = make([]map[int]struct{}, maxCol)
}
for i, claim := range claims {
for row := 0; row < claim.height; row++ {
for col := 0; col < claim.width; col++ {
if grid[row+claim.nbInchesTop][col+claim.nbInchesLeft] == nil {
grid[row+claim.nbInchesTop][col+claim.nbInchesLeft] = make(map[int]struct{})
}
grid[row+claim.nbInchesTop][col+claim.nbInchesLeft][i] = struct{}{}
}
}
}
for i := 0; i < len(claims); i++ {
overlap := false
loop:
for row := 0; row < len(grid); row++ {
for col := 0; col < len(grid[0]); col++ {
v := grid[row][col]
_, exists := v[i]
if len(v) > 1 && exists {
overlap = true
break loop
}
}
}
if !overlap {
return i + 1
}
}
return -1
}