A simple Game of Life implementation in Java
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

123456789101112131415161718192021222324252627282930313233
  1. package edu.stuy.goldfish.rules;
  2. import edu.stuy.goldfish.Grid;
  3. import edu.stuy.goldfish.Patch;
  4. // An implementation of conway using von Neumann Neighborhoods.
  5. public class Conway4 extends RuleSet {
  6. public static int states = 2;
  7. public static Grid run (Grid g) {
  8. Grid newGrid = new Grid(g.getWidth(), g.getHeight());
  9. for (int i = 0; i < g.getWidth(); i++) {
  10. for (int j = 0; j < g.getHeight(); j++) {
  11. Patch[] neighbors = g.getPatch(i, j).get4Neighbors();
  12. int numAlive = 0;
  13. for (Patch p : neighbors)
  14. if (p.getState() == 1) numAlive++;
  15. Patch p = g.getPatch(i,j).clone(newGrid);
  16. if (numAlive < 2) {
  17. p.setState(0); //Dies by underpopulation
  18. }
  19. if (numAlive > 3) {
  20. p.setState(0); //Dies by overpopulation
  21. }
  22. if (numAlive == 3)
  23. p.setState(1); //Born with 3 neighbors.
  24. newGrid.setPatch(i,j,p);
  25. }
  26. }
  27. return newGrid;
  28. }
  29. }