TopCoder problem "CellularAutomaton" used in TCO10 Round 2 (Division I Level One)



Problem Statement

    In this problem you will be exploring the evolution of cellular automaton depending on its initial configuration. The cellular automaton consists of a two-dimensional rectangular grid of cells and a rules string. Each cell of the grid can exist in one of two states: live or dead.



The evolution of the automaton happens step-by-step in the following way. On each step, for each cell we calculate the number L of live cells which are adjacent to it (vertically, horizontally or diagonally). The cells of leftmost and rightmost columns are considered to be adjacent, as well as cells of topmost and bottommost rows. Once L is calculated, the state of the cell changes accordingly to the L-th element of the rules:
  • if it is '=', the state of the cell doesn't change;
  • if it is '-'('+'), the cell becomes dead (live) regardless of its previous state;
  • if it is 'X', the state of cell changes to its opposite.
Thus, the rules string for Conway's Game of Life is "--=+-----". All cells change their states simultaneously, so for each cell the number of live neighbors is calculated before any changes are performed.



Your task is: given the rules string of the automaton and its initial configuration, change the states of some cells to obtain a new initial configuration so that the quantity of live cells after a certain number of iterations is maximized.

Implementation Details

Your code should implement one method configure(String[] grid, String rules, int N, int K). grid gives you the initial configuration of the grid: grid[i][j] is the state of cell in row i and column j and is '1' (one) for live or '0' (zero) for dead. rules is the string of automata rules, N is the number of cells that can be changed and K is the number of evolution steps that will be done.



You have to return a String[] of same dimensions as grid which contains new initial configuration of the automaton (with states of at most N cells changed).

Scoring

Your score for a test case is calculated as number of live cells after K iterations (starting with the configuration you've returned), divided by the total number of cells on the grid. Your overall score is a sum of individual scores over all test cases. Invalid return of any kind (invalid dimensions of grid, character other than '0' and '1', changing states of more than N cells etc.) results in zero score for that test case.

Tools

A visualization tool is provided for offline testing. It also allows manual play as well as manual fixing of your program's return.
 

Definition

    
Class:CellularAutomaton
Method:configure
Parameters:String[], String, int, int
Returns:String[]
Method signature:String[] configure(String[] grid, String rules, int N, int K)
(be sure your method is public)
    
 

Notes

-Parameters R, C, N and K are chosen randomly and uniformly (except for the first test case). All cells of grid are generated independently, the probability of a cell being live is chosen as a parameter as 0.3..0.7. The rules are generated as follows: first two and last two characters are set to '-', the rest of characters are chosen randomly with equal probabilities.
-The memory limit is 1024 MB and the time limit is 10 seconds per test case (which includes only time spent in your code). There is no explicit code size limit.
-There are 10 example test cases and 100 full submission test cases.
 

Constraints

-The numbers of rows R and columns C in grid will be between 10 and 100, inclusive.
-N will be between 5 and (R*C)/16, inclusive (integer division used).
-K will be between 2 and 20, inclusive.
-Your return must have the same dimensions as grid and differ from it in at most N characters.
 

Examples

0)
    
"1"
Returns: "seed = 1
R = 12
C = 12
rules = --=+-----
N = 9
K = 2
"
1)
    
"2"
Returns: "seed = 2
R = 23
C = 50
rules = ----X=X--
N = 23
K = 11
"
2)
    
"3"
Returns: "seed = 3
R = 99
C = 29
rules = --X+X=X--
N = 28
K = 6
"
3)
    
"4"
Returns: "seed = 4
R = 52
C = 83
rules = ----+-X--
N = 124
K = 14
"
4)
    
"5"
Returns: "seed = 5
R = 83
C = 59
rules = --X=+X---
N = 92
K = 5
"
5)
    
"6"
Returns: "seed = 6
R = 34
C = 36
rules = --X++++--
N = 40
K = 13
"
6)
    
"7"
Returns: "seed = 7
R = 98
C = 54
rules = --+--X+--
N = 292
K = 17
"
7)
    
"8"
Returns: "seed = 8
R = 49
C = 30
rules = --XX=----
N = 90
K = 6
"
8)
    
"9"
Returns: "seed = 9
R = 55
C = 74
rules = --=-+-X--
N = 197
K = 5
"
9)
    
"10"
Returns: "seed = 10
R = 84
C = 41
rules = --=XX==--
N = 179
K = 8
"

Problem url:

http://www.topcoder.com/stat?c=problem_statement&pm=10989

Problem stats url:

http://www.topcoder.com/tc?module=ProblemDetail&rd=14273&pm=10989

Writer:

Unknown

Testers:

Problem categories:

Simulation