Skip to content
Snippets Groups Projects

Compare revisions

Changes are shown as if the source revision was being merged into the target revision. Learn more about comparing revisions.

Source

Select target project
No results found
Select Git revision

Target

Select target project
  • das.s/tp3
  • f19002502/tp3
  • r17010960/tp3
  • l19004806/tp3
  • y19010055/tp3
  • o18034026/tp3
  • z18029613/tp3
  • p19021289/tp3
  • d19027596/tp3
  • f18010428/tp3
  • f19003868/tp3
  • c19022214/tp3
  • c19017929/tp3
  • m16014784/tp3
  • a19028956/tp3
  • c19026071/tp3
  • h18008908/tp3
17 results
Select Git revision
Show changes
Commits on Source (2)
import java.util.Arrays;
import java.util.Iterator;
import java.util.List;
import java.util.Random;
import java.util.*;
/**
* {@code Grid} instances represent the grid in <i>The Game of Life</i>.
......@@ -98,29 +95,73 @@ public class Grid implements Iterable<Cell> {
}
private boolean[][] calculateNextStates() {
return null;
boolean [][] state = new boolean[numberOfRows][numberOfColumns];
for (int i = 0; i < state.length; i++) {
for (int j = 0; j < state[i].length; j++) {
if (calculateNextState(i, j, cells[i][j] ))
state[i][j] = true;
else
state[i][j] = false;
}
}
return state;
}
private boolean calculateNextState(int rowIndex, int columnIndex, Cell cell) {
int aliveNeighbours = countAliveNeighbours(rowIndex, columnIndex);
if (cell.isDead() && aliveNeighbours == 3)
return true;
if (cell.isAlive() && aliveNeighbours == 2 || aliveNeighbours == 3)
return true;
else
return false;
}
private int countAliveNeighbours(int rowIndex, int columnIndex) {
return 0;
int aliveNeighbours = 0;
for (int i = 0; i < getNeighbours(rowIndex, columnIndex).size(); i++) {
Cell cell = getNeighbours(rowIndex, columnIndex).get(i);
boolean cellState = cell.isAlive();
if (cellState)
aliveNeighbours++;
}
return aliveNeighbours;
}
private List<Cell> getNeighbours(int rowIndex, int columnIndex) {
return null;
List<Cell> neighbours = new ArrayList<>();
neighbours.add(getCell(rowIndex, columnIndex + 1));
neighbours.add(getCell(rowIndex + 1, columnIndex + 1));
neighbours.add(getCell(rowIndex + 1, columnIndex));
neighbours.add(getCell(rowIndex + 1, columnIndex -1));
neighbours.add(getCell(rowIndex, columnIndex - 1));
neighbours.add(getCell(rowIndex - 1, columnIndex - 1));
neighbours.add(getCell(rowIndex - 1, columnIndex));
neighbours.add(getCell(rowIndex - 1, columnIndex + 1));
return neighbours;
}
private void goToNextState(boolean[][] nextState) {
for (int i = 0; i < nextState.length; i++) {
for (int j = 0; j < nextState[i].length; j++) {
if (nextState[i][j])
getCell(i, j).setAlive();
else
getCell(i, j).setDead();
}
}
}
/**
* Sets all {@link Cell}s in this {@code Grid} as dead.
*/
void clear() {
boolean [][] clearState = new boolean[numberOfRows][numberOfColumns];
for (int i = 0; i < clearState.length; i++) {
Arrays.fill(clearState[i], false);
}
goToNextState(clearState);
}
/**
......@@ -131,6 +172,10 @@ public class Grid implements Iterable<Cell> {
*/
void randomGeneration(Random random) {
boolean [][] randomState = new boolean[numberOfRows][numberOfColumns];
for (int i = 0; i < randomState.length; i++) {
Arrays.fill(randomState[i], random.nextBoolean());
}
goToNextState(randomState);
}
}
\ No newline at end of file