The AP Games is the result of the completion of the project Tic-Tac-Toe with AI at JetBrains Academy. This project was developed just for fun and to learn Python and some concepts of a decision-making algorithm.
Tic-tac-toe, is a paper-and-pencil game for two players, X and O, who take turns marking the spaces in a 3×3 grid. The player who succeeds in placing three of their marks in a horizontal, vertical, or diagonal row is the winner.
Reversi is a strategy board game for two players who take turns marking the spaces in an 8x8 board.
Each player must place the piece so that an opponent's piece, or a row of opponent's pieces, is flanked by your pieces. All of the opponent's pieces between your pieces are then turned over to become your color. The object of the game is to own more pieces than your opponent when the game is over. See source.
The example below shows the game interface:
Please choose the game:
1 - Tic-Tac-Toe;
2 - Reversi.
Type "exit" to exit the program.
Input command:
2
Type "start player1 player2" to run the game, where "player1" and "player2"
is one of the supported values: user, easy, medium, hard, nightmare;
Type "rules" to get game rules or type "exit" to exit from the game.
Input command:
rules
You must place the piece so that an opponent's piece, or a row of
opponent's pieces, is flanked by your pieces.
All of the opponent's pieces between your pieces are then turned over to
become your color. The object of the game is to own more pieces than
your opponent when the game is over.
Input command:
start
Bad parameters!
Input command:
start user hard
-------------------
8 | |
7 | |
6 | |
5 | X O |
4 | O X |
3 | |
2 | |
1 | |
-------------------
1 2 3 4 5 6 7 8
Enter the coordinate [X]:
1 1
You cannot go here!
Enter the coordinate [X]:
1
You should enter two numbers!
Enter the coordinate [X]:
4 3
-------------------
8 | |
7 | |
6 | |
5 | X O |
4 | X X |
3 | X |
2 | |
1 | |
-------------------
1 2 3 4 5 6 7 8
Making move level "hard" [O]
-------------------
8 | |
7 | |
6 | |
5 | X O |
4 | O X |
3 | O X |
2 | |
1 | |
-------------------
1 2 3 4 5 6 7 8
Enter the coordinate [X]:
The project has been tested only with python 3.8 on Ubuntu Linux and Windows 10. If you have python 3.8 and above installed in your machine, just install the AP Games from PyPI:
python --version
pip install ap-games
You can find source code of this package on github. See aplatkouski/ap-games repository.
Run module:
python -m ap_games [game] [player1 player2]
Where:
game
is a value from the following set:1
ortic-tac-toe
for Tic-Tac-Toe game;2
orreversi
for Reversi game.
player1
andplayer2
are values from the following set:user
for human player;easy
,medium
,hard
andnightmare
for AI player.
Note: Parameters in brackets are optional.
Or open the python console and type:
# Python version 3.8+
from ap_games import cli
cli.main()
This package can be run as a console game or integrated into another application. This project provides the following basic structures:
SquareGameboard
GameBase
TicTacToe
Reversi
Player
HumanPlayer
AIPlayer
- uses mini-max as decision-making algorithm.
Thanks to Gaurav Sen for his video What is the Minimax Algorithm? - Artificial Intelligence
Development of this happens on GitHub, patches including tests, documentation are very welcome, as well as bug reports!
This project has a code of conduct. By interacting with this repository, organization, or community you agree to abide by its terms.
See also our CONTRIBUTING.md.
Copyright (c) 2020 Artsiom Platkouski. AP_games
is licensed under the
MIT License - see the LICENSE.txt file for details.