Итак, код работает отлично, если я пытаюсь найти размер земли посередине, но это не удается при расчете размера маленькой земли в углу. Как мне вернуть 0
, если он начнет проверку земли за пределами заданных массивов?Как мне определить массив, который не существует?
M = 'land'
o = 'water'
world = [[o,o,o,o,o,o],
[o,M,M,M,o,o],
[o,o,M,M,o,o],
[o,o,o,o,o,M]]
def continent_size world, x, y
if world[x][y] != 'land'
return 0
end
size = 1
world[x][y] = 'counted land'
size = size + continent_size(world, x-1, y-1)
size = size + continent_size(world, x , y-1)
size = size + continent_size(world, x+1, y-1)
size = size + continent_size(world, x-1, y )
size = size + continent_size(world, x+1, y )
size = size + continent_size(world, x-1, y+1)
size = size + continent_size(world, x , y+1)
size = size + continent_size(world, x+1, y+1)
size
end
puts continent_size(world, 3, 5)
Исправьте изложить в словах, что 'continent_size мир, х, y' предназначена для возврата. Небольшой пример был бы полезен. –