Недавно я для забавы реализовал «Игру жизни» Конвея в Javascript (на самом деле coffeescript, но то же самое). Поскольку javascript можно использовать в качестве функционального языка, я пытался придерживаться этого конца спектра. Я не был доволен моими результатами. Я довольно хороший ОО-программист, и мое решение попахивает все тем же, старым и старым. Короткий вопрос: каков функциональный стиль (псевдокод) для этого?
Вот псевдокод для моей попытки:
class Node
update: (board) ->
get number_of_alive_neighbors from board
get this_is_alive from board
if this_is_alive and number_of_alive_neighbors < 2 then die
if this_is_alive and number_of_alive_neighbors > 3 then die
if not this_is_alive and number_of_alive_neighbors == 3 then alive
class NodeLocations
at: (x, y) -> return node value at x,y
of: (node) -> return x,y of node
class Board
getNeighbors: (node) ->
use node_locations to check 8 neighbors
around node and return count
nodes = for 1..100 new Node
state = new NodeState(nodes)
locations = new NodeLocations(nodes)
board = new Board(locations, state)
executeRound:
state = clone state
accumulated_changes = for n in nodes n.update(board)
apply accumulated_changes to state
board = new Board(locations, state)