mirror of
https://github.com/onyx-and-iris/aoc2025.git
synced 2025-12-07 22:57:50 +00:00
Compare commits
3 Commits
2add30a6c1
...
432d14e248
| Author | SHA1 | Date | |
|---|---|---|---|
| 432d14e248 | |||
| c8c523dd66 | |||
| f9e99d1d2c |
@ -13,8 +13,8 @@ class Main
|
||||
@sum = 0
|
||||
|
||||
grid = Grid.new(data)
|
||||
(0...grid.rows.size).each do |row_index|
|
||||
(0...grid.columns.size).each do |column_index|
|
||||
(0...grid.size).each do |row_index|
|
||||
(0...grid[row_index].size).each do |column_index|
|
||||
cell = grid.cell_at(row_index, column_index)
|
||||
next unless cell.value == "@"
|
||||
|
||||
|
||||
@ -15,15 +15,15 @@ class Main
|
||||
grid = Grid.new(data)
|
||||
loop do
|
||||
grid_updated = false
|
||||
(0...grid.rows.size).each do |row_index|
|
||||
(0...grid.columns.size).each do |column_index|
|
||||
(0...grid.size).each do |row_index|
|
||||
(0...grid[row_index].size).each do |column_index|
|
||||
cell = grid.cell_at(row_index, column_index)
|
||||
next unless cell.value == "@"
|
||||
|
||||
if cell.neighbours.count do |neighbour|
|
||||
neighbour.value == "@"
|
||||
end < 4
|
||||
data[row_index][column_index] = "x"
|
||||
grid[row_index][column_index].value = "x"
|
||||
@sum += 1
|
||||
grid_updated = true
|
||||
end
|
||||
@ -31,7 +31,6 @@ class Main
|
||||
end
|
||||
|
||||
break unless grid_updated
|
||||
grid = Grid.new(data)
|
||||
end
|
||||
|
||||
puts @sum
|
||||
|
||||
@ -1,10 +1,14 @@
|
||||
require "forwardable"
|
||||
|
||||
require_relative "cell"
|
||||
|
||||
class Grid
|
||||
attr_reader :rows, :columns
|
||||
attr_reader :columns
|
||||
extend Forwardable
|
||||
def_delegators :@data, :size, :[]
|
||||
|
||||
def initialize(input)
|
||||
@rows = []
|
||||
@data = []
|
||||
(0...input.size).each do |row_index|
|
||||
row = []
|
||||
(0...input[row_index].size).each do |column_index|
|
||||
@ -12,27 +16,26 @@ class Grid
|
||||
cell.value = input[row_index][column_index]
|
||||
row << cell
|
||||
end
|
||||
@rows << row
|
||||
@data << row
|
||||
end
|
||||
@columns = @rows.transpose
|
||||
|
||||
# Link neighbours
|
||||
(0...@rows.size).each do |row_index|
|
||||
(0...@columns.size).each do |column_index|
|
||||
cell = @rows[row_index][column_index]
|
||||
cell.n = @rows[row_index - 1][column_index] if row_index - 1 >= 0
|
||||
cell.ne = @rows[row_index - 1][column_index + 1] if row_index - 1 >= 0 && column_index + 1 < @columns.size
|
||||
cell.e = @rows[row_index][column_index + 1] if column_index + 1 < @columns.size
|
||||
cell.se = @rows[row_index + 1][column_index + 1] if row_index + 1 < @rows.size && column_index + 1 < @columns.size
|
||||
cell.s = @rows[row_index + 1][column_index] if row_index + 1 < @rows.size
|
||||
cell.sw = @rows[row_index + 1][column_index - 1] if row_index + 1 < @rows.size && column_index - 1 >= 0
|
||||
cell.w = @rows[row_index][column_index - 1] if column_index - 1 >= 0
|
||||
cell.nw = @rows[row_index - 1][column_index - 1] if row_index - 1 >= 0 && column_index - 1 >= 0
|
||||
(0...@data.size).each do |row_index|
|
||||
(0...@data[row_index].size).each do |column_index|
|
||||
cell = @data[row_index][column_index]
|
||||
cell.n = @data[row_index - 1][column_index] if row_index - 1 >= 0
|
||||
cell.ne = @data[row_index - 1][column_index + 1] if row_index - 1 >= 0 && column_index + 1 < @data[row_index - 1].size
|
||||
cell.e = @data[row_index][column_index + 1] if column_index + 1 < @data[row_index].size
|
||||
cell.se = @data[row_index + 1][column_index + 1] if row_index + 1 < @data.size && column_index + 1 < @data[row_index + 1].size
|
||||
cell.s = @data[row_index + 1][column_index] if row_index + 1 < @data.size
|
||||
cell.sw = @data[row_index + 1][column_index - 1] if row_index + 1 < @data.size && column_index - 1 >= 0
|
||||
cell.w = @data[row_index][column_index - 1] if column_index - 1 >= 0
|
||||
cell.nw = @data[row_index - 1][column_index - 1] if row_index - 1 >= 0 && column_index - 1 >= 0
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
def cell_at(row, column)
|
||||
@rows[row][column]
|
||||
@data[row][column]
|
||||
end
|
||||
end
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user