Page 1: Remembering the Moves and Possible Wins
Unit 3, Lab 3, Page 1
On this page, you’ll prepare by allowing the program to record the moves that are made, and teach it the winning groups of three squares.
When you first wrote Tic Tac Toe, it was easy to detect illegal moves (moving to a square that’s already wearing an X or O costume) because each sprite could test for that without knowing about the rest of the game board. But to detect wins and ties, the program needs a way to test the state of the whole game board, not just one individual piece. So, you’ll use a global variable, , to keep track of whether the square in each position is empty or filled with an X or an O.
You learned about global variables on Unit 2 Lab 1 Page 4: Keeping Score with Global Variables.
- Open your U3L1-TicTacToe project, and save it as U3L3-TicTacToe so you’ll still have your old version when you edit the new one.
-
Make a global variable called board that, at the beginning of the game, contains a list with the numbers from 1 to 9.
Each sprite needs to know its own position on the board so that you can use the replace item () of (list) with ()
block to replace that position with an X or an O. So, you’ll create a sprite variable, , and each clone will have its own version of this variable.
: Sprite Variable
A sprite variable is like a global variable in that it doesn’t belong to a particular script, but it does belong to a particular sprite.
-
You learned about initializing variables on Unit 2 Lab 1 Page 1: Developing a Number Guessing Game with Script Variables.
Create a sprite variable position number.
You make a sprite variable similarly to how you make global variables:
- Click in the Variables palette.
- Then, as you are typing the variable’s name, select “for this sprite only” to make it a sprite variable.
-
As you create the clones, set each one’s position number to the appropriate value (1-9).
Click for a hint on setting the position number.
In the loop that makes the clones, increase the parent sprite’s variable by one for each new clone so that each clone will have a unique value.
Make sure that the parent’s position number doesn’t end up being a number 1-9 so that it doesn’t conflict with a clone.
- When a square is clicked, use the replace () of (list) with () block (found towards the bottom of the red palette) to update that square’s entry in the board list with X or O as appropriate.
- Watch the values stored in the board variable as you play a game of Tic Tac Toe. Make sure that it updates as you expect it to, and fix any bugs.
Storing All the Ways to Win
To program a way to detect a win, you need to determine what counts as a win. You’ll store each possible winning triple as a list of three position numbers (a triple). For example, this winning triple could be represented as because the win is in the 3rd, 5th, and 7th positions:
-
- How many winning triples are possible?
- Write down each of the possible winning triples.
You could check for each possible win separately:
But that’s way too much code, especially because you’ll have to do something very similar again, later on, when the computer actually plays against you. Instead, you’ll create a list to store all of the possible winning triples so you can check it against the current state of the game stored by board.
-
Create a reporter that outputs a list of all possible winning triples. It will look something like this:
-