Question

In: Computer Science

In Python: Please complete the following two tasks in Tic Tac Toe: 1. Allow the user...

In Python: Please complete the following two tasks in Tic Tac Toe:

1. Allow the user to choose heads/tails to see if the user goes first or the computer and alter your code accordingly.

2. Allow the user to play again.

Add a simple strategy for the AI to play against the user.

Solutions

Expert Solution

Here is the code with both your requirements fulfilled.

Have a nice day :)

import random

def drawBoard(board):
        print(board[1] + '|' + board[2] + '|' + board[3])
        print('-+-+-')
        print(board[4] + '|' + board[5] + '|' + board[6])
        print('-+-+-')
        print(board[7] + '|' + board[8] + '|' + board[9])


def inputPlayerLetter():
        letter=''
        while not(letter=='X' or letter=='O'):
                print("Do you want to be 'X' or 'O'?")
                letter = input().upper()

        if letter == 'X':
                return ['X','O']
        else:
                return ['O','X']


def whoGoesFirst():
        print('Do you want to go first? (Yes or No)')
        if  input().lower().startswith('y'):
                return 'player'
        else:
                return 'computer'


def playAgain():
        print('Do you want to play again? (Yes or No)')
        return input().lower().startswith('y')


def makeMove(board, letter, move):
        board[move] = letter


def isWinner(board,letter):
        return ((board[1]==letter and board[2]==letter and board[3]==letter) or
                        (board[4]==letter and board[5]==letter and board[6]==letter) or
                        (board[7]==letter and board[8]==letter and board[9]==letter) or
                        (board[1]==letter and board[4]==letter and board[7]==letter) or
                        (board[2]==letter and board[5]==letter and board[8]==letter) or
                        (board[3]==letter and board[6]==letter and board[9]==letter) or
                        (board[1]==letter and board[5]==letter and board[9]==letter) or
                        (board[3]==letter and board[5]==letter and board[7]==letter))


def getBoardCopy(board):
        dupBoard = []
        for i in board:
                dupBoard.append(i)
        return dupBoard


def isSpaceFree(board, move):
        return board[move] == ' '


def getPlayerMove(board):
        move = '' 
        while move not in '1 2 3 4 5 6 7 8 9'.split() or not isSpaceFree(board,int(move)):
                print('What is your next move? (1-9)')
                move = input()
        return int(move)


def chooseRandomMoveFromList(board, movesList):
        possibleMoves = []
        for i in movesList:
                if isSpaceFree(board, i):
                        possibleMoves.append(i)

        if len(possibleMoves) != 0:
                return random.choice(possibleMoves)
        else:
                return None


def minimax(board, depth, isMax, alpha, beta, computerLetter):
        if computerLetter == 'X':
                playerLetter = 'O'
        else:
                playerLetter = 'X'
        if isWinner(board, computerLetter):
                return 10
        if isWinner(board, playerLetter):
                return -10
        if isBoardFull(board):
                return 0
        if isMax:
                best = -1000
                for i in range(1,10):
                        if isSpaceFree(board, i):
                                board[i] = computerLetter
                                best = max(best, minimax(board, depth+1, not isMax, alpha, beta, computerLetter) - depth)
                                alpha = max(alpha, best)
                                board[i] = ' '
                                if alpha >= beta:
                                        break
                return best
        else:
                best = 1000
                for i in range(1,10):
                        if isSpaceFree(board, i):
                                board[i] = playerLetter
                                best = min(best, minimax(board, depth+1, not isMax, alpha, beta, computerLetter) + depth)
                                beta = min(beta, best)
                                board[i] = ' '
                                if alpha >= beta:
                                        break
                return best


def findBestMove(board, computerLetter):
        if computerLetter == 'X':
                playerLetter = 'O'
        else:
                playerLetter = 'X'
        bestVal = -1000
        bestMove = -1
        for i in range(1,10):
                if isSpaceFree(board, i):
                        board[i] = computerLetter
                        moveVal = minimax(board, 0, False, -1000, 1000, computerLetter)
                        board[i] = ' '
                        if moveVal > bestVal:
                                bestMove = i
                                bestVal = moveVal
        return bestMove


def isBoardFull(board):
        for i in range(1,10):
                if isSpaceFree(board, i):
                        return False
        return True


print('\nWelcome to Tic Tac Toe!\n')
print('Reference of numbering on the board')
drawBoard('0 1 2 3 4 5 6 7 8 9'.split())
print('')

while True:
        theBoard = [' '] * 10
        playerLetter, computerLetter = inputPlayerLetter()
        turn = whoGoesFirst()
        print('The ' + turn + ' will go first.')
        gameIsPlaying = True
        while gameIsPlaying:
                if turn == 'player':
                        drawBoard(theBoard)
                        move = getPlayerMove(theBoard)
                        makeMove(theBoard, playerLetter, move)
                        if isWinner(theBoard, playerLetter):
                                drawBoard(theBoard)
                                print('You won the game')
                                gameIsPlaying = False
                        else:
                                if isBoardFull(theBoard):
                                        drawBoard(theBoard)
                                        print('The game is a tie')
                                        break
                                else:
                                        turn = 'computer'
                else:
                        move = findBestMove(theBoard, computerLetter)
                        makeMove(theBoard, computerLetter, move)
                        if isWinner(theBoard, computerLetter):
                                drawBoard(theBoard)
                                print('You lose the game')
                                gameIsPlaying = False
                        else:
                                if isBoardFull(theBoard):
                                        drawBoard(theBoard)
                                        print('The game is a tie')
                                        break
                                else:
                                        turn = 'player'
        if not playAgain():
                break

Related Solutions

Python Code Needed Two-Player, Two-Dimensional Tic-Tac-Toe Write a script to play two-dimensional Tic-Tac-Toe between two human...
Python Code Needed Two-Player, Two-Dimensional Tic-Tac-Toe Write a script to play two-dimensional Tic-Tac-Toe between two human players who alternate entering their moves on the same computer. Create a 3-by-3 two-dimensional array. Each player indicates their moves by entering a pair of numbers representing the row and column indices of the square in which they want to place their mark, either an 'X' or an 'O'. When the first player moves, place an 'X' in the specified square. When the second...
please create a tic tac toe game with python using only graphics.py library
please create a tic tac toe game with python using only graphics.py library
Write a program that plays tic-tac-toe. The tic-tac-toe game is played on a 3 × 3...
Write a program that plays tic-tac-toe. The tic-tac-toe game is played on a 3 × 3 grid as shown below: The game is played by two players, who take turns. The first player marks moves with a circle, the second with a cross. The player who has formed a horizontal, vertical, or diagonal sequence of three marks wins. Your program should draw the game board, ask the user for the coordinates of the next mark (their move), change the players...
PLEASE READ VERY CAREFULLY write a client.py and server.py file for tic-tac-toe IN PYTHON with the...
PLEASE READ VERY CAREFULLY write a client.py and server.py file for tic-tac-toe IN PYTHON with the following restrictions (SO WRITE TWO FILES THAT PLAY PYTHON THROUGH A SOCKET) Use a 5 x 5 grid (dimensions are subject to change, so use constants for NUM_ROWS and NUM_COLS) Use 'X' for player 1 and 'O' for player 2 (symbols and the number of players is subject to change, so use constants) Each player can make 1 move per turn before having to...
If anyone can please write a code for a 5x5 tic tac toe game in matlab...
If anyone can please write a code for a 5x5 tic tac toe game in matlab I would greatly appreciate it. Its extra credit. PLEASE HELP ME :(
Perk Company produces three products: Tic, Tac, and Toe. Tic requires 90 machine setups, Tac requires...
Perk Company produces three products: Tic, Tac, and Toe. Tic requires 90 machine setups, Tac requires 80 setups, and Toe requires 330 setups. Berk has identified an activity cost pool with allocated overhead of $18,000 for which the cost driver is machine setups. How much overhead is assigned to the Tic product?
How to make tic tac toe game in javascript with vue.js
How to make tic tac toe game in javascript with vue.js
C# (Tic-Tac-Toe) Create class TicTacToe that will enable you to write a complete app to play...
C# (Tic-Tac-Toe) Create class TicTacToe that will enable you to write a complete app to play the game of Tic-Tac-Toe. The class contains a private 3-by-3 rectangular array of integers. The constructor should initialize the empty board to all 0s. Allow two human players. Wherever the first player moves, place a 1 in the specified square, and place a 2 wherever the second player moves. Each move must be to an empty square. After each move, determine whether the game...
Game of Tic Tac Toe with the following conditions A point system where a  move that leads...
Game of Tic Tac Toe with the following conditions A point system where a  move that leads to a winning game is given 1 point, a move that leads to a tie is given 0 point, and a  lead to a losing game will get -1 point. Grid size of 5x5 A timer that can be set for how long a game can be played 5 symbols in a row to get a point Connected lines cannot be crossed (No diagonal lines)...
explain a pseudocode for tic tac toe in c++ between a computer and a player in...
explain a pseudocode for tic tac toe in c++ between a computer and a player in words
ADVERTISEMENT
ADVERTISEMENT
ADVERTISEMENT