Example Competition Strategies
Pure Random
Firing blocks are selected randomly from the board. Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to randomly selecting open spaces for the next shot until the enemy fleet is sunk.
Random Checkerboard
View the board as a checkerboard, with half the squares red and half black. Randomly select black blocks from the board. Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to randomly selecting open black squares for the next shot until the enemy fleet is sunk.
Red vs Blue
This strategy refines the random checkerboard strategy by first searching a further refined grid in order to guarantee sinking the carrier. Color diagonals A1-J10, A5-F10, A9-B10, E1-J6, and I1-J2 red. Also color diagonals C1-J8, A3-H10, G1-J4, A7-D10 blue. Now first fire randomly at the red squares. Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process). Then go back to firing at red squares only if the carrier has not been sunk, or else randomly at red and blue squares if the carrier has already been sunk.
Random Switch Parity
This strategy offers an interesting variant of the "checkerboard" random algorithms above, where we split objects into different colored groups. We say that two numbers have the same parity if they are both even or both odd, and opposite parity if one is even and one is odd. Likewise, we say that two letters have opposite parity if one of the letters is one of the following: A,C,E,G, or I and the other letter is one of the following: B,D,F,H,J. Starting with an initial shot any random place on the board, always choose the next shot randomly from the available spaces but such that the new letter and number both have opposite parity to the letter and number of the previous shot. (Unless no such shot is left on the board, in which case, shoot with the same parity as the previous shot). Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to the algorithm described above.
Conic Search
We call this the conic search, because one-dimensional cones look like X's. Given any starting center cell, we will fire shots in an X pattern, proceeding outward from the center first in a northwest direction, then northeast, southwest, and finally southeast. In each case, we try all the squares in the X pattern sequentially from the center until we hit the boundary. Our first X has center at A5. Each time we finish a particular X pattern, we start a new one whose center is two squares to the right of the previous (eg. A5 then C5 then E5 ...). Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to the algorithm described above.
Union Jack Search
We call this the Union Jack search, since the pattern drawn out looks like a superimposed cross and X centered in the board. The premise is to follow a very specific shot order as described in the following diagram.
A | B | C | D | E | F | G | H | I | J | |
1 | 5 | 44-50 | 44-50 | 44-50 | 22 | 44-50 | 44-50 | 44-50 | 44-50 | 7 |
2 | 38-43 | 15 | 65-100 | 65-100 | 23 | 65-100 | 65-100 | 65-100 | 18 | 51-57 |
3 | 38-43 | 65-100 | 14 | 65-100 | 24 | 65-100 | 65-100 | 17 | 65-100 | 51-57 |
4 | 38-43 | 65-100 | 65-100 | 13 | 25 | 65-100 | 16 | 65-100 | 65-100 | 51-57 |
5 | 30 | 31 | 32 | 33 | 1 | 3 | 34 | 35 | 36 | 37 |
6 | 38-43 | 65-100 | 65-100 | 9 | 2 | 4 | 65-100 | 65-100 | 65-100 | 51-57 |
7 | 38-43 | 65-100 | 10 | 65-100 | 26 | 65-100 | 19 | 65-100 | 65-100 | 51-57 |
8 | 38-43 | 11 | 65-100 | 65-100 | 27 | 65-100 | 65-100 | 20 | 65-100 | 51-57 |
9 | 12 | 65-100 | 65-100 | 65-100 | 28 | 65-100 | 65-100 | 65-100 | 21 | 51-57 |
10 | 6 | 58-64 | 58-64 | 58-64 | 29 | 58-64 | 58-64 | 58-64 | 58-64 | 8 |
We fire space-by-space in the order assigned to each square. For example, we start with shooting at E5, followed by shooting at E6. For squares that feature a range of numbers, we randomly choose an ordering of those square so that the order we fire into them is random but occurs after lower numbered squares. Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to the algorithm described above.
Quadrants Search
We call this the quadrants search because it divides up the board into four quadrants where the action takes place.
A | B | C | D | E | F | G | H | I | J | |
1 | 38 | 23 | 45 | 27 | 40 | |||||
2 | 3 | 4 | 51 | 6 | 7 | |||||
3 | 24 | 17 | 22 | 26 | 18 | 28 | ||||
4 | 2 | 1 | 5 | 8 | ||||||
5 | 49 | 21 | 37 | 39 | 25 | 46 | ||||
6 | 48 | 33 | 43 | 41 | 29 | 50 | ||||
7 | 16 | 13 | 9 | 10 | ||||||
8 | 36 | 20 | 34 | 30 | 19 | 32 | ||||
9 | 15 | 14 | 52 | 12 | 11 | |||||
10 | 44 | 35 | 47 | 31 | 42 |
stuff After we've finished the above, if the fleet has not been completely sunk we have only missed the 2x1. Randomly shoot at spaces with an adjacent empty cells where the remaining ship might be hiding until the fleet is sunk. Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to the algorithm described above.
Diagonal Search + Random Checkerboard
This algorithm combines aspects of the random checkerboard strategy above with the less random search-type strategies focused on identifying the placement of large ships. The first part of the algorithm consists of diagonal searches in the order described here:
A | B | C | D | E | F | G | H | I | J | |
1 | 23 | 21 | 9 | |||||||
2 | 24 | 19 | 7 | |||||||
3 | 17 | 5 | ||||||||
4 | 18 | 3 | ||||||||
5 | 20 | 1 | 15 | |||||||
6 | 22 | 2 | 13 | |||||||
7 | 4 | 11 | ||||||||
8 | 6 | 12 | ||||||||
9 | 8 | 14 | 25 | |||||||
10 | 10 | 16 | 26 |
Now imagine that we color the whole board with red and black squares in a checkerboard style. Notice that all of the planned shots above occur on red squares. If the enemy fleet is not yet sunk, continue randomly choosing red squares until the fleet is sunk. Whenever a hit occurs, follow up by sinking the ship (and any other ships incidentally identified in the process), and then go back to the algorithm described above.