Assignment 5
Type: Group Assignment
Due: by 10:00 PM on Wednesday, May 1, 2019
Prologue
This is a group assignment. Be sure to review the suggestions you wrote for the Code of Conduct and be careful to adhere to it when working on the assignment. Keep in mind that you both must be authors of all code submitted and are strongly encouraged to only work on the assignment when you are with your partner.
Summary
In this assignment, you will write a simple game of Tic-Tac-Toe. It is a two-player game that is played on a 3x3 board where the players take turns marking the squares of the board. Player 0 plays with X’s and Player 1 plays with O’s (We’re computer scientists, so we count from zero, of course!) A player wins if they can get three marks in a row in any direction (vertical, horizontal, or diagonal).
Below is an example 3x3 grid that shows the end state of the board after a game is completed.
X | O | X |
X | O | |
O | X |
In the above game, the players took turns marking cells in the grid until one player obtains three in a row or there are no more places to play. Here Player 0 (i.e. X) wins because they were able to obtain three X’s in a row.
Below is a game that ended in a draw.
X | O | X |
X | O | O |
O | X | X |
Starter Code
To begin the assignment, start by downloading the following two files and putting them in the same directory. I recommend that you create a folder in your StuWork
directory called assignment5
and place them both in there.
The graphics.py
file is the one developed by Zelle and is provided through his website. Note that you can find a detailed summary of all classes, methods, and functions provided in this library on the Resources page.
The tictactoe.py
file is a partial implementation of the tic-tac-toe game. Your assignment is to finish writing this program.
What Functions You Need to Write
The main program of the tic-tac-toe game is already completed for you in the tictactoe.py
file. However, there are several functions that are defined but not yet implemented. Your assignment is to finish implementing all of these functions. There are five of them in total and are listed below:
drawBoard(win, board)
updateBoard(board, point, player)
validMove(board, point)
checkWinner(board)
drawEndGameMessage(win, winner)
Detailed documentation is provided for each function inside the tictactoe.py
.
Tips for Completing the Assignment
Step 0: Get the Code
Go get the Starter Code and place both files in one directory as described.
Step 1: Familiarize Yourself with the Code
Begin by familiarizing yourself with the tictactoe.py
file. I suggest you do the following in order.
- Take a close look at the structure of the file; locate the
main()
function to see how it works. You will not need to edit this function, but knowing the basic components will be helpful. - Note that in
main()
there is aboard
variable that is a 3x3 grid. Make sure you understand what this is. Consider playing around with it by copying and pasting it into a REPL and try changing some of its values by executing statements likeboard[0][0] = "X"
orboard[1][2] = "O"
to see how it changes. - Try putting a
print(point)
statement after thepoint = win.getMouse()
line of code and run the program from theTerminal
. Now try clicking on the window that appears and take a look at the coordinates of thepoint
that is registered. - Make sure you know the role of the
curPlayer
,winner
, andmovesSoFar
variables.
Step 2: Drawing the Board
Next I suggest you implement the drawBoard
function. Here are a few things to get you started.
- Take a very close look at the documentation of the function and make sure you understand what it is supposed to do.
- Draw a white rectangle that takes up the entire window so that it covers up any previous boards that have been drawn with a white canvas.
- Draw four black lines so that the window is separated into nine squares of equal size. You may want to review the Line documentation and experiment with how they work in the REPL before doing in the
tictactoe.py
file. - Try experimenting by drawing a single
X
or a singleO
in the center of certain cells on the grid. The goal is to get them to appear perfectly centered. Once you have the hang of drawing characters to the board, delete your experimental code and move on. - Finish writing the function using two nested loops that iterates over the cells of the
board
parameter and draws the string from the board. I suggest you loop overrange(3)
twice so that you can access the current value withboard[row][column]
for some iteration variablesrow
andcolumn
. - Try testing your function by manually editing the
board
variables inmain()
so that it also has"X"
and"O"
values and make sure they appear in the right spots.
Step 3: Updating the Board
Next I suggest you implement the updateBoard
function.
- Take a very close look at the documentation of the function and make sure you understand what it is supposed to do.
- Insert that
print(point)
statement back into themain()
function right after thepoint = win.getMouse()
line. Try running the program and clicking around so that you know what points are generated by clicks. - Think about how you can figure out what row and column of the grid
point
object is in. Remember thatboard[0][0]
is the upper left cell,board[2][2]
is the lower right, andboard[1][0]
is the second row first column. Thereforeboard[row][column]
will always give you the value in rowrow
and columncolumn
. You will need to use thepoint.getX()
andpoint.getY()
methods to get the x and y-coordinates of the point and then usefloor
and/orceiling
from themath
library in some interesting way to convert it to a row/column. - Then update the board with the
player
character usingboard[row][column] = player
. - Try testing your function by running the programming and clicking in different regions to see if the X’s and O’s appear in the right spots.
Step 4: Validating Moves
Next I suggest you implement the validMove
function.
- You already know how to turn a
point
into arow
andcolumn
. Do this again here. - Check if
board[row][column]
is an open cell (i.e. the empty string), if it is returnTrue
and otherwise returnFalse
.
Step 5: Checking if a Player Won
The most difficult part of this assignment is checking if one of the players has won the game in the checkWinner
function. This requires checking if there are three identical characters in a row either vertically, horizontally, or diagonally. There are eight possible different ways each player could win and each will have to be checked. Try to make use of loops and/or helper functions to solve this problem rather than hard coding a 16-case conditional covering all the possibilities!
Step 6: The End Game
The last step is to implement the drawEndGameMessage
function that simply displays a message to the players who won the game. You have complete freedom on how to implement this function, but the user must always know the outcome of the game from the message. For example, you could draw a red rectangle and put the text “Player X Wins!” or “Close game! It was a draw!” or something equally helpful in identifying the final result of the game.
How to Turn in Your Code
a. Make sure that you and your partner are clearly identified at the top of every file you have created for this assignment.
b. All of your files need to be placed into the Hand-in/USERNAME/assignment5
directory. You can do this visually in Finder
by copying all of your files in your StuWork/USERNAME/assignment5
directory into your Hand-in/USERNAME/assignment5
directory. (Note that you only need to do this once—it is not necessary for every member of your group to submit separately.)
c. Send all of your files to your partner so they have access to them, too!