Skip to content

Latest commit

 

History

History

Tic-Tac-Toe

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 

Tic Tac Toe

Python projects

About this project

Tic-tac-toe is a game played by two players on a 3x3 field where the duel takes place. One of the players plays as 'X', and the other player is 'O'. 'X' plays first, then the 'O' side plays, and so on.

The first player that writes 3 'X' or 3 'O' in a straight line (including diagonals) wins.

Run

Requirements:

python tictactoe.py

Python projects

Code it yourself

1. Welcome to the battlefield!

Description

Nowadays, this game is known all over the world. Each country may have its own version of the name, sometimes the rules are different, but the meaning of the game remains the same.

Objectives

Your first task in this project is to print any state of the field in the console output. Do not forget to show the moves for both players.

Example

The example below shows how your output might look.

X O X
O X O
X X O 

The user is the gamemaster

Description

However, our game should show the field in an "intermediate" states too. Let's try to visualize different combinations that the user will determine from the input. It is also important to think about the interface and set boundaries for our field.

Objectives

In this stage, you should write a program that:

  1. Reads 9 symbols from the input and writes an appropriate 3x3 field. Elements of the field can contain only 'X', 'O' and '_' symbols.
  2.  Sets the field to a specific format, i.e. field should start and end with ---------, all lines in between should start and end with '|' symbol and everything in the middle should be separated with a single space.  

Examples

Examples below show how your output should look. 
The greater-than symbol followed by space () represents the user input. Notice that it's not the part of the input.

Example 1:

Enter cells: > O_OXXO_XX

---------
| O _ O |
| X X O |
| _ X X |
---------

Example 2: 

Enter cells: > OXO__X_OX

---------
| O X O |
| _ _ X |
| _ O X |
---------

Example 3: 

Enter cells: > XO__X__

---------
| _ X O |
| _ _ X |
| _ _ _ |
---------

What's up on the field?

Description

It is time to learn to see the result (or lack thereof) of the game. In this stage, you should analyze a Tic-Tac-Toe field.  

Is the winner already known or is the game not over yet?  Is it a draw or an impossible combination of moves?  Let's find out!

Note. In this stage either 'X' or 'O' can start the game.

Objectives

In this stage, your program should:

  1.  Fill the field from the input and print it as in the previous stage.
  2.  Find the state in which the game is at the moment and print it. Possible states:
  • "Game not finished" - when no side has a three in a row but the field has empty cells;
  • "Draw" - when no side has a three in a row and the field has no empty cells;
  • "X wins" - when the field has three X in a row;
  • "O wins" - when the field has three O in a row;
  • "Impossible" - when the field has three X in a row as well as three O in a row. Or the field has a lot more X's that O's or vice versa (if the difference is 2 or more, should be 1 or 0). For this stage, consider that the game can be started both as X's or as O's. 

Also, you can use ' ' or '_' to print empty cells - it's up to you.

Examples

The examples below show outputs for some predefined states. Your program should work in the same way. 
The greater-than symbol followed by space () represents the user input. Notice that it's not the part of the input.

Example 1:


Enter cells: > XXXOO__O_
---------
| X X X |
| O O _ |
| _ O _ |
---------
X wins

Example 2:


Enter cells: > XOXOXOXXO
---------
| X O X |
| O X O |
| X X O |
---------
X wins

Example 3:


Enter cells: > XOOOXOXXO
---------
| X O O |
| O X O |
| X X O |
---------
O wins

Example 4:


Enter cells: > XOXOOXXXO
---------
| X O X |
| O O X |
| X X O |
---------
Draw

Example 5:


Enter cells: > XO_OOX_X_
---------
| X O   |
| O O X |
|   X   |
---------
Game not finished

Example 6:


Enter cells: > XO_XO_XOX
---------
| X O _ |
| X O _ |
| X O X |
---------
Impossible

Example 7:


Enter cells: > _O_X__X_X
---------
|   O   |
| X     |
| X   X |
---------
Impossible

Example 8:


Enter cells: > _OOOO_X_X
---------
|   O O |
| O O   |
| X   X |
---------
Impossible

First move!

Description

In addition to analyzing the field, it is equally important to add the ability to select a cell for your move. Now you need to implement human moves. Let's divide the field into cells.

Suppose the bottom left cell has the coordinates (1, 1) and the top right cell has the coordinates (3, 3) like in this table:

(1, 3) (2, 3) (3, 3)
(1, 2) (2, 2) (3, 2)
(1, 1) (2, 1) (3, 1)

The program should ask to enter the coordinates where the user wants to make a move.

Note that in this stage user moves as X, not O. Keep in mind that the first coordinate goes from left to right and the second coordinate goes from bottom to top. Also, notice that coordinates start with 1 and can be 1, 2 or 3.

But what if the user enters incorrect coordinates? The user could enter symbols instead of numbers or enter coordinates representing occupied cells. You need to prevent all of that by checking a user's input and catching possible exceptions.

 

Objectives

The program should work in the following way:

  1. Get the 3x3 field from the input as in the previous stages.
  2. Output this 3x3 field with cells before the user's move.
  3. Then ask the user about his next move.
  4. Then the user should input 2 numbers that represent the cell on which user wants to make his X or O. (9 symbols representing the field would be on the first line and these 2 numbers would be on the second line of the user input)
  5. Analyze user input and show messages in the following situations:
    -"This cell is occupied! Choose another one!" - if the cell is not empty;
    -"You should enter numbers!" - if the user enters other symbols;
    -"Coordinates should be from 1 to 3!" - if the user goes beyond the field.
  6. Then output the table including the user's most recent move.

The program should also check user input. If the user input is unsuitable, the program should ask him to enter coordinates again. 

So, you need to output a field from the first line of the input and then ask the user to enter a move. Keep asking until the user enters coordinate that represents an empty cell on the field and after that output the field with that move. You should output the field only 2 times - before the move and after a legal move.

Do not delete code that checks for table state; it will be useful in the future.

Examples

The examples below shows how your program should work. 
The greater-than symbol followed by space () represents the user input. Notice that it's not the part of the input.

Example 1:


Enter cells: > X_X_O____
---------
| X   X |
|   O   |
|       |
---------
Enter the coordinates: > 1 1
---------
| X   X |
|   O   |
| X     |
---------

Example 2: 


Enter cells: > _XXOO_OX_
---------
|   X X |
| O O   |
| O X   |
---------
Enter the coordinates: > 1 3
---------
| X X X |
| O O   |
| O X   |
---------

Example 3: 


Enter cells: > _XXOO_OX_
---------
|   X X |
| O O   |
| O X   |
---------
Enter the coordinates: > 3 1
---------
|   X X |
| O O   |
| O X X |
---------

Example 4:


Enter cells: > _XXOO_OX_
---------
|   X X |
| O O   |
| O X   |
---------
Enter the coordinates: > 3 2
---------
|   X X |
| O O X |
| O X   |
---------

Example 5:


Enter cells: > _XXOO_OX_
---------
|   X X |
| O O   |
| O X   |
---------
Enter the coordinates: > 1 1
This cell is occupied! Choose another one!
Enter the coordinates: > 1 3
---------
| X X X |
| O O   |
| O X   |
---------

Example 6:


Enter cells: > _XXOO_OX_
---------
|   X X |
| O O   |
| O X   |
---------
Enter the coordinates: > one
You should enter numbers!
Enter the coordinates: > one three
You should enter numbers!
Enter the coordinates: > 1 3
---------
| X X X |
| O O   |
| O X   |
---------

Example 7:


Enter cells: > _XXOO_OX_
---------
|   X X |
| O O   |
| O X   |
---------
Enter the coordinates: > 4 1
Coordinates should be from 1 to 3!
Enter the coordinates: > 1 4
Coordinates should be from 1 to 3!
Enter the coordinates: > 1 3
---------
| X X X |
| O O   |
| O X   |
---------

Fight!

Description

We are at the finish line! But playing alone is not so interesting, is it? Let's combine our successes in past stages and get Tic-Tac-Toe with the ability to play from the beginning (empty field) to the result (win or draw).

Now it is time to make a working game!

In the last stage, make it so you can play a full game with a friend. First one of you moves as X, and then the other one moves as O.

Objectives

In this stage, you should write a program that:

  1. Prints an empty field at the beginning of the game.
  2. Creates a game loop where the program asks the user to enter the cell coordinates, analyzes the move for correctness and shows a field with the changes if everything is ok.
  3. Ends the game when someone wins or there is a draw.

You need to output the final result after the end of the game.

Good luck gaming!

Example

The example below shows how your program should work.
The greater-than symbol followed by space () represents the user input. Notice that it's not the part of the input.



---------
|       |
|       |
|       |
---------
Enter the coordinates: > 2 2
---------
|       |
|   X   |
|       |
---------
Enter the coordinates: > 2 2
This cell is occupied! Choose another one!
Enter the coordinates: > two two
You should enter numbers!
Enter the coordinates: > 1 4
Coordinates should be from 1 to 3!
Enter the coordinates: > 1 3
---------
| O     |
|   X   |
|       |
---------
Enter the coordinates: > 3 1
---------
| O     |
|   X   |
|     X |
---------
Enter the coordinates: > 1 2
---------
| O     |
| O X   |
|     X |
---------
Enter the coordinates: > 1 1
---------
| O     |
| O X   |
| X   X |
---------
Enter the coordinates: > 3 2
---------
| O     |
| O X O |
| X   X |
---------
Enter the coordinates: > 2 1
---------
| O     |
| O X O |
| X X X |
---------
X wins