1
0
Fork 0
advent-of-code-2024/08/8-1.rb

80 lines
1.6 KiB
Ruby
Executable file

#!/usr/bin/env ruby
problem = 8
input = File.readlines("#{problem}.input").map(&:strip)
#input = DATA.read.split("\n")
# Find diferent antennas
signals = input.join.chars.uniq
.reject { _1 == "." }
.map { [_1, []] }
.to_h
grid = input.map(&:chars)
# map antenna locations
signals.keys.each do |signal|
grid.each_with_index do |row, x|
row.each_with_index do |val, y|
signals[val] << [x, y] if val == signal
end
end
end
# calculate antinodes between all node pairs
antinodes = []
signals.each do |(signal, locations)|
locations.combination(2).each do |(first, second)|
x = (first.first - second.first).abs
y = (first.last - second.last).abs
if first.first < second.first
x1 = first.first - x
x2 = second.first + x
else
x1 = first.first + x
x2 = second.first - x
end
if first.last < second.last
y1 = first.last - y
y2 = second.last + y
else
y1 = first.last + y
y2 = second.last - y
end
antinode_1 = [x1, y1]
antinode_2 = [x2, y2]
#require "debug";debugger
antinodes << antinode_1 if x1 >= 0 && y1 >= 0 && x1 < grid.size && y1 < grid.first.size
antinodes << antinode_2 if x2 >= 0 && y2 >= 0 && x2 < grid.size && y2 < grid.first.size
end
end
p antinodes.uniq.size
grid.each_with_index do |row, x|
row.each_with_index do |val, y|
if antinodes.index([x,y])
print "#"
else
print grid[x][y]
end
end
puts
end
__END__
............
........0...
.....0......
.......0....
....0.......
......A.....
............
............
........A...
.........A..
............
............