Problem Statement |
| You are given a map of a gold mine.
Each cell may contain a piece of gold and/or several layers of rocks.
You can move through cells without rocks, destroy rocks using dynamite cartridges of several types and collect gold from rocks-free cells.
The number of moves you can perform and the number of dynamite cartridges of each type that you can use is limited.
Given all these limitations, your task is to get as much gold as you can.
Implementation
The map of the mine is a rectangular section divided in cells, W cells wide (east-west direction) and H cells high (north-south direction).
Your code should implement a single method collectGold(int[] dynamite, int[] effect, int W, int[] gold, int[] rocks). Its parameters give you the following information:
You start at cell (0,0) (north-west corner of the map). In one move you can:
-
move one cell east (use 'E'), west ('W'), south ('S') or north ('N'). You can move only through cells which have 0 layers of rock. When you move to a cell which contains a piece of gold, you pick it up, the piece is removed from the cell, and its value is added to the total value of gold you've collected. It's not allowed to move outside the map.
-
put one dynamite cartridge at your current position by using digit 'k', where k is 0-based index of dynamite type to use. The cartridge explodes 5 moves after putting it: if you put the cartridge as move i, the rocks are destroyed between moves i+5 and i+6. If immediately after move i+5 you are in a cell where rocks will be destroyed with the explosion (i.e., the corresponding element of effect is positive), you get hurt and your score for the test case is 0. If a cell contains n layers of rocks and the explosion destroys at least n+1 layers of rocks, then all rocks in this cell will be destroyed and, if there's a piece of gold in this cell, it will be destroyed as well.
-
stay where you are by using '-'.
The return from the method should be the list of at most maxMoves moves you'll do while exploring the mine, in order. The i-th character of your return gives your choice of move i. After the exploration is over (all moves of the return are executed), you stay where you are until all dynamite cartridges you've put explode, and than you automatically get out of the mine using any gold-free route (this is always possible), so you can still lose your gold (if you're damaged with an explosion), but can't acquire it.
Scoring
Your score for each test case will be the total value of gold you have collected. Invalid return of any kind (using a type of dynamite you've run out of, using invalid character for move, moving outside of the map or to a cell with non-zero number of layers of rocks, using too many moves etc.) results in 0 score.
Your overall score will be the sum of your individual scores, each of them divided by the greatest score achieved by anyone for that test case.
Visualizer
A visualization tool is provided for offline testing. It also allows manual play. |
|
Definition |
| Class: | RockyMine | Method: | collectGold | Parameters: | int[], int[], int, int[], int[], int | Returns: | String | Method signature: | String collectGold(int[] dynamite, int[] effect, int W, int[] gold, int[] rocks, int maxMoves) | (be sure your method is public) |
|
|
|
|
Notes |
- | 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 |
- | All variables are generated randomly and independently, and have uniform distribution unless otherwise stated. |
- | W and H will be between 10 and 100, inclusive. |
- | In each cell of the map, rocks will be between 0 and 9, inclusive, and gold will be generated as a normally distributed Gaussian value, multiplied by 10, rounded to the nearest integer and truncated to fit within [0, 63] interval (negative values are replaced with 0, values larger than 63 - with 63). |
- | D will be between 2 and 7, inclusive. |
- | For each type of dynamite, its quantity will be between 1 and (H-2)*(W-2)/24+1 (integer division), and its effect will be as a matrix with 0 damage at the center and 0..4 damage at other cells. Additionally, the matrix will be symmetrical with respect to the middle row, the middle column and both primary and secondary diagonals. |
- | maxMoves will be between (W*H)/8 (integer division) and W*H. |
|
Examples |
0) | |
| | Returns: "seed = 1
H = 10
W = 10
maxMoves = 48
D = 6" | |
|
1) | |
| | Returns: "seed = 2
H = 50
W = 23
maxMoves = 685
D = 5" | |
|
2) | |
| | Returns: "seed = 3
H = 29
W = 99
maxMoves = 1384
D = 2" | |
|
3) | |
| | Returns: "seed = 4
H = 83
W = 52
maxMoves = 3121
D = 2" | |
|
4) | |
| | Returns: "seed = 5
H = 59
W = 83
maxMoves = 3696
D = 4" | |
|
5) | |
| | Returns: "seed = 6
H = 36
W = 34
maxMoves = 519
D = 6" | |
|
6) | |
| | Returns: "seed = 7
H = 54
W = 98
maxMoves = 1664
D = 4" | |
|
7) | |
| | Returns: "seed = 8
H = 30
W = 49
maxMoves = 676
D = 2" | |
|
8) | |
| | Returns: "seed = 9
H = 74
W = 55
maxMoves = 2920
D = 2" | |
|
9) | |
| | Returns: "seed = 10
H = 41
W = 84
maxMoves = 2518
D = 3" | |
|