Skip to content

Latest commit

 

History

History
57 lines (38 loc) · 2.21 KB

README.md

File metadata and controls

57 lines (38 loc) · 2.21 KB

Tic-Tac-Toe NxM Game

This is a simple implementation of the classic Tic-Tac-Toe game using the GTK+ library in C. Unlike the traditional 3x3 grid, this version allows for a customizable grid size, making it an NxM grid where players aim to align N symbols in a row to win.

Features

  • NxM Grid: Play on a grid of custom size.
  • Turn-based Play: Players take turns to place their symbols (X or O) on the grid.
  • Win Detection: The game detects when a player aligns N symbols in a row horizontally, vertically, or diagonally to declare a winner.
  • Reset and Restart: You can reset the game or restart with a different grid size.

Requirements

  • GTK+ 3: Ensure you have GTK+ 3 installed on your system to compile and run this application.

Usage

  1. Compilation: Use a C compiler to build the application. For example:

    make
    
  2. Execution: Run the compiled executable:

    ./Tic-Tac-Toe.exe
    
  3. Gameplay: Follow on-screen instructions to set the grid size and play the game.

Controls

  • Mouse Click: Click on the grid cells to place your symbol.

Structure

  • Tic-Tac-Toe_BASIC.c: Contains the main C code for the Tic-Tac-Toe game (NxN).
  • Tic-Tac-Toe_FLEX.c: Contains the main C code for the Tic-Tac-Toe game (NxM).
  • main.c, app.c and app.h : Contains the main C code for the Tic-Tac-Toe game (NxM). Also divided into 3 parts to be more readable.
  • Tic-Tac-Toe_AI.c: Contains the main C code for the Tic-Tac-Toe game (NxM). Try to implement AI for solo playing.
  • Minimax.c: Contains the main C code for the Minimax algorithm for 3x3
  • Project.c: Contains the main C code for the basic CLI Tic-Tac-Toe NxN game
  • README.md: This file, providing information and instructions for the application.
  • Makefile : Compile file for the most stable version.

Contributing

Feel free to contribute to this project by forking it, making improvements, and creating a pull request.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Next...

  1. Fixing the problem about implementation of the AI code.
  2. Adding new game mode support
  3. Fixing the bugs and improve performance