6 "adventofcode2022/utils"
7 "adventofcode2022/utils/inputs"
8 "adventofcode2022/utils/grid2d"
11 func Part1(input string) int {
12 grid := inputs.ToGrid2D(input, "\n", "", -1, utils.MustAtoi)
13 visible := grid2d.NewGrid(grid.SizeX(), grid.SizeY(), false)
15 for j := 0; j < grid.SizeY(); j++ {
16 for i := 0; i < grid.SizeX(); i++ {
17 directions := [][]int{{0, 1}, {0, -1}, {1, 0}, {-1, 0}}
18 for _, dir := range directions {
25 if x < 0 || x >= grid.SizeX() || y < 0 || y >= grid.SizeY() {
28 if grid.Get(i, j) <= grid.Get(x, y) {
34 visible.Set(i, j, true)
42 for j := 0; j < visible.SizeY(); j++ {
43 for i := 0; i < visible.SizeX(); i++ {
44 if visible.Get(i, j) {
52 func Part2(input string) int {
53 grid := inputs.ToGrid2D(input, "\n", "", -1, utils.MustAtoi)
54 scenicScore := grid2d.NewGrid(grid.SizeX(), grid.SizeY(), 1)
56 for j := 0; j < grid.SizeY(); j++ {
57 for i := 0; i < grid.SizeX(); i++ {
58 directions := [][]int{{0, 1}, {0, -1}, {1, 0}, {-1, 0}}
59 for _, dir := range directions {
66 if x < 0 || x >= grid.SizeX() || y < 0 || y >= grid.SizeY() {
69 if grid.Get(i, j) <= grid.Get(x, y) {
75 scenicScore.Set(i, j, scenicScore.Get(i,j) * score)
81 for j := 0; j < scenicScore.SizeY(); j++ {
82 for i := 0; i < scenicScore.SizeX(); i++ {
83 if scenicScore.Get(i, j) > max {
84 max = scenicScore.Get(i, j)