Saya baru-baru ini menerapkan untuk bersenang-senang Permainan Kehidupan Conway di Javascript (sebenarnya kopi tapi hal yang sama). Karena javascript dapat digunakan sebagai bahasa fungsional, saya mencoba untuk tetap menggunakan spektrum itu. Saya tidak senang dengan hasil saya. Saya seorang programmer OO yang cukup bagus dan solusi saya sama-sama-sama-sama tua. Singkatnya, pertanyaan panjang: apa gaya fungsional (pseudocode) untuk melakukannya?
Inilah Pseudocode untuk usaha saya:
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)