An ** m,n,k-game** is an abstract board game in which two players take turns in placing a stone of their color on an

*m,n,k*-games are mainly of mathematical interest. One seeks to find the game-theoretic value, which is the result of the game with perfect play. This is known as solving the game.

A standard strategy stealing argument from combinatorial game theory shows that in no *m,n,k*-game can there be a strategy that assures that the second player will win (a second-player winning strategy). This is because an extra stone given to either player in any position can only improve that player's chances. The strategy stealing argument assumes that the second player has a winning strategy and demonstrates a winning strategy for the first player. The first player makes an arbitrary move to begin with. After that, he or she pretends that he or she is the second player and adopts the second player's winning strategy. He or she can do this as long as the strategy doesn't call for placing a stone on the 'arbitrary' square that is already occupied. If this happens, though, he or she can again play an arbitrary move and continue as before with the second player's winning strategy. Since an extra stone cannot hurt him or her, this is a winning strategy for the first player. The contradiction implies that the original assumption is false, and the second player cannot have a winning strategy.

This argument tells nothing about whether a particular game is a draw or a win for the first player. Also, it does not actually give a strategy for the first player.

A useful notion is a "weak *(m,n,k)* game", where k-in-a-row by the second player does not end the game with a second player win.

If weak *(m,n,k)* is a draw, then any smaller (in *m* and *n*) normal and weak *(m,n,k)* games are also a draw.

Conversely, if weak or normal *(m,n,k)* is a win, then any larger weak *(m,n,k)* is a win.

Note that proofs of draws using pairing strategies also prove a draw for the weak version and thus for all smaller versions.

The following statements refer to the first player, assuming that both players use an optimal strategy.

*k ≥ 9*is a draw: when*k = 9*and the board is infinite, the second player can draw via a "pairing strategy". A draw on an infinite board means that the game will go on forever with perfect play. A pairing strategy involves dividing all the squares of the board into pairs in such a way that by always playing on the pair of the first player's square, the second player is ensured that the first player cannot get*k*in a line. A pairing strategy on an infinite board can be applied to any finite board as well - if the strategy calls for making a move outside the board, then the second player makes an arbitrary move inside the board.*k ≥ 8*is a draw on an infinite board. It is not clear if this strategy applies to any finite board sizes. It is not known if the second player can force a draw when*k*is 6 or 7 on an infinite board.*k ≥ 3*and either*k > m*or*k > n*is a draw, also by a pairing strategy in the dimension not smaller than k (or trivially impossible to win if both are smaller)

*k*= 1 and*k*= 2 are trivial wins, except for (1,1,2) and (2,1,2)*k*= 3 is a draw for (3,3,3) (see Tic-tac-toe) or if*m < 3*or*n < 3*. It is a win otherwise.- (
*m*,4,4) is a win for*m*≥ 30 (Lustenberger, 1967) and a draw for*m ≤ 8*. - (5,5,4) is a draw.
- (6,5,4) is a win.
- (6,6,5) is a draw.
- Computer search by L. Victor Allis has shown that (15,15,5) is a win, even with one of the restrictive rules of Gomoku.

It is possible to consider variants played on a multidimensional instead of a bidimensional board.

For the case of *k*-in-a-row where the board is an *n*-dimensional hypercube with all edges with length *k*, Hales and Jewett proved that the game is a draw if *k* is odd and

*k*≥ 3^{n}- 1

or if *k* is even and

*k*≥ 2^{n+1}- 2.

They conjecture that the game is a draw also when the number of cells is at least twice the number of lines, which happens if and only if

- 2
*k*^{n}≥ (*k*+ 2)^{n}.

COMMENTS

Tabletop games: Rules and Strategy