Весела обнови решението на 15.04.2013 12:24 (преди почти 12 години)
+
+
+class TicTacToeBoard:
+
+ def __init__(self):
+ self.board = {x + y: " " for x in "ABC" for y in "123"}
+ self.status = "Game in progress."
+ self.last_turn = None
+
+ def __setitem__(self, position, move):
+ if(position not in self.board.keys()):
+ raise InvalidKey
+ if(self.board[position] != ' '):
+ raise InvalidMove
+ if(move not in ('X', 'O')):
+ raise InvalidValue
+ if(self.last_turn == move):
+ raise NotYourTurn
+ self.last_turn = move
+ self.board[position] = move
+ if self.status == "Game in progress.":
+ self.update_status(position, move)
+
+ def __getitem__(self, position):
+ if(position not in self.board.keys()):
+ raise InvalidKey
+ return self.board[position]
+
+ def __str__(self):
+ draw_board = '\n' + ' '+'-'*13 + '\n' + '3 | ' +\
+ self.board["A3"] + ' | ' + self.board["B3"] +\
+ ' | ' + self.board["C3"] + ' |\n' +\
+ ' '+'-'*13 + '\n' + '2 | ' + self.board["A2"] +\
+ ' | ' + self.board["B2"] + ' | '+self.board["C2"] +\
+ ' |\n' + ' ' + '-'*13 + '\n' + '1 | ' + self.board["A1"] +\
+ ' | ' + self.board["B1"] + ' | ' + self.board["C1"] +\
+ ' |\n'+' A B C \n'
+ return draw_board
+
+ def game_status(self):
+ return self.status
+
+ def update_status(self, position, move):
+ row_win = True
+ col_win = True
+ diag_win = True
+ board = self.board
+ for i in "123":
+ a = position[0] + i
+ if board[a] == ' ' or board[a] != move:
+ col_win = False
+ for i in "ABC":
+ a = i + position[1]
+ if board[a] == ' ' or board[a] != move:
+ row_win = False
+ diag1 = board["A1"] + board["B2"] + board["C3"]
+ diag2 = board["A3"] + board["B2"] + board["C1"]
+ diag_win = move*3 == diag1 or move*3 == diag2
+ if col_win or row_win or diag_win:
+ self.status = move + " wins!"
+ elif " " not in board.values():
+ self.status = "Draw!"
+
+
+class InvalidMove(Exception):
+ def __init__(self):
+ pass
+
+
+class InvalidKey(Exception):
+ def __init__(self):
+ pass
+
+
+class InvalidValue(Exception):
+ def __init__(self):
+ pass
+
+
+class NotYourTurn(Exception):
+ def __init__(self):
+ pass
По-добре си направи изключенията така: MyException(Exception): pass и ги възбуждай така, ако настояваш за съобщение: raise MyException('my exceptional message')
Покрай условията в условен оператор нямаш нужда от скоби(гледа се лошо на тях). Употребата им е допустима само, когато става дума за определяне на приоритет или да направиш неявен такъв малко по-лесно четим.
__str__
метода ти може да се възползва от малко форматиране на низове.
В update_status
могат да се избегнат повторения и да се направи по-стегнат като си подготвиш и опишеш всички случаи, които имаш нужда да проверяваш предварително.