This app implements a tic tac toe game of the user against the computer.
The game chooses a random player to start the game. You have always the "X" and the opponent (computer) has always the "O".
The Game can finish with either a win, a loss or a draw.
It then prompts you for a new game.
I hope you enjoy the game!
This game uses a modified minimax algorithm1.
The AI first checks* if the computer can win on the next move, then checks if it has to prevent the player from winning in the next move.
If neither of the above apply, it then plays according to the minimax algorithm1.
I believe that you will find the overall AI behaviour quite competitive, resulting most of the times in a draw.
A demo is available here:
https://tic-tac-toe-pl2022.netlify.app
A compiled version is ready in dist directory.
You will need to have npm installed in order to modify and rebuild.
$ npm install
package.json comes with the following scripts:
$ npm run build
Builds the dist folder in development mode
$ npm run prod
Builds the dist folder in production mode
(The dist provided in this repo was made with this command)
$ npm run dev
Runs the app in a development server at localhost:3000
This app is an excersise during my self education in web design. I focused more on the css/javascript part rather than the actual logic of the AI. My contribution in the AI was the addition of the initial check* before using the minimax algorithm.
PL, 2022
1 Minimax Algorithm in Game Theory | Set 3 (Tic-Tac-Toe AI – Finding optimal move)