parent
1aeb80d0eb
commit
038495b353
@ -0,0 +1,31 @@
|
|||||||
|
require "set"
|
||||||
|
|
||||||
|
INPUT = ARGF.read.split("\n").map {|l| l.chars.map(&:to_i) }
|
||||||
|
|
||||||
|
NEIGHBORS = [[0,-1], [-1, 0], [1, 0], [0, 1]]
|
||||||
|
def neighbors(y,x)
|
||||||
|
NEIGHBORS
|
||||||
|
.map {|dy,dx| [y+dy, x+dx] }
|
||||||
|
.select {|y,x| (0...INPUT.size).cover?(y) && (0...INPUT[0].size).cover?(x) }
|
||||||
|
end
|
||||||
|
|
||||||
|
all = (0...INPUT.size).flat_map {|y| (0...INPUT[0].size).map {|x| [y, x]}}
|
||||||
|
lows = all.select {|y,x| neighbors(y,x).all? {|yy,xx| INPUT[yy][xx] > INPUT[y][x] }}
|
||||||
|
# p lows.sum {|y,x| INPUT[y][x] + 1 }
|
||||||
|
|
||||||
|
def fill_basin(low)
|
||||||
|
basin = Set.new([low])
|
||||||
|
|
||||||
|
stack = [low]
|
||||||
|
until stack.empty?
|
||||||
|
y,x = stack.shift
|
||||||
|
new_neighbors = neighbors(y,x).reject {|y,x| basin.include?([y,x]) || INPUT[y][x] == 9 }
|
||||||
|
stack.concat(new_neighbors)
|
||||||
|
basin.merge(new_neighbors)
|
||||||
|
end
|
||||||
|
|
||||||
|
basin
|
||||||
|
end
|
||||||
|
|
||||||
|
p lows.map { fill_basin(_1) }.map(&:size).sort[-3, 3].inject(:*)
|
||||||
|
|
Loading…
Reference in new issue