- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试为模拟内存匹配游戏的程序编写 Python 3 代码:
Write a program that plays the memory matching game. When it starts, the program prompts the user for the number of rows and columns for the game board that contains the cards. The total number of cards must be even. Assume that the board dimensions are at most 8 by 9 or 9 by 8. Your cards must be numbered from 1 through (number of rows * number of columns) / / 2. Your program allows the player to specify the cards that she would like to select through a coordinate system.
我已经写了所有内容,但我不断遇到一个小错误,我一生都无法弄清楚。当我尝试使用以下示例输入运行程序时,收到错误“列表索引超出范围”:
>>> main()
Enter number of rows 3
Enter number of columns 3
> ***The value of rows X columns must be even. Try again.***
Enter number of rows 2
Enter number of columns 3
> * * *
> * * *
Enter coordinates for first card 3 1 [THE ERROR IS GENERATED HERE]
<<<
我知道在这种情况下 3 位于数组之外,但我编写的代码应该以字符串的形式返回错误消息。相反,程序崩溃了。如果有人能引导我走向正确的方向,我将不胜感激。这是我编写的完整代码:
import random
class Card(object):
def __init__(self,value):
self._face = 0
self._value = value
def __str__(self):
if self._face == True:
output = str(self._value)
else:
output = "*"
return output
def __eq__(self,other):
if type(self)!=type(other):
output = False
elif self._value == other._value:
output = True
else:
output = False
return output
class Deck(object):
def __init__(self, pairs):
self._pairs = pairs
self._cards = []
for cards in range(self._pairs):
self._cards.append(Card(cards))
self._cards.append(Card(cards))
def shuffle(self):
random.shuffle(self._cards)
def deal(self,index):
return self._cards[index]
def cardsleft(self):
return len(self._cards)
class Game(object):
def __init__(self,rows,columns):
self._rows = rows
self._columns = columns
self._cards = (rows*columns)//2
self._deck = Deck(self._cards)
self._quit = False
self._turns = 0
#deals the cards into a 2D list
def populateBoard(self):
k = 0
self._board = []
self._deck.shuffle()
for i in range(self._rows):
self._board.append([])
for j in range(self._columns):
self._board[i].append(self._deck.deal(k))
k+=1
#shows the cards on the board
def displayBoard(self):
output = ""
for i in range(self._rows):
for j in range(self._columns):
output += (str(self._board[i][j]) + " ")
output += "\n"
print(output)
#iterates through the cards to see if any are face down. if all pairs have been found, gameover
def isGameOver(self):
victory = True
for i in range(self._rows):
for j in range(self._columns):
if self._board[i][j]._face == False:
victory = False
break
if victory == True:
print("You Win.")
return victory
'''def play(self):
self.populateBoard()
while self._quit == False:
self.displayBoard()
self._coord1 = input("Enter the coordinates for the first card ").split(' ')
self._coord1 = list(map(int, self._coord1))
if (self._coord1[0]-1 < self._columns) and (self._coord1[1]-1 < self._rows) and (self._coord1[0]-1 >= 0) and (self._coord1[1]-1 >= 0):
self._card1 = self._board[self._coord1[0]-1][self._coord1[1]-1]
else:
self._card1 = "***Invalid coordinates! Try again.***"
while self._card1 == "***Invalid coordinates! Try again.***":
print("Coordinates outside gameboard. Please give coordinates on the board")
self._coord1 = input("Enter the coordinates for the first card ").split(' ')
self._coord1 = list(map(int, self._coord1))
if (self._coord1[0]-1 < self._columns) and (self._coord1[1]-1 < self._rows) and (self._coord1[0]-1 >= 0) and (self._coord1[1]-1 >= 0):
self._card1 = self._board[self._coord1[0]-1][self._coord1[1]-1]
else:
self._card1 = "***Invalid coordinates! Try again.***"
self._card1._face = 1
self._coord2 = input("Enter the coordinates for the second card ").split(' ')
self._coord2 = list(map(int, self._coord2))
if (self._coord2[0]-1 < self._columns) and (self._coord2[1]-1 < self._rows) and (self._coord2[0]-1 >= 0) and (self._coord2[1]-1 >= 0):
self._card2 = self._board[self._coord2[0]-1][self._coord2[1]-1]
else:
self._card2 = "***Invalid coordinates! Try again.***"
while self._card2 == "***Invalid coordinates! Try again.***" or self._card2._face == 1:
if self._card2 == "***Invalid coordinates! Try again.***":
print("Coordinates outside gameboard. Please give coordinates on the board")
else:
print("you have already selected that card. give coordinates for a facedown card")
self._coord2 = input("Enter the coordinates for the second card ").split(' ')
self._coord2 = list(map(int, self._coord2))
if (self._coord2[0]-1 < self._columns) and (self._coord2[1]-1 < self._rows) and (self._coord2[0]-1 >= 0) and (self._coord2[1]-1 >= 0):
self._card2 = self._board[self._coord2[0]-1][self._coord2[1]-1]
else:
self._card2 = "***Invalid coordinates! Try again.***"
self._card2._face = 1
if self._card1 == self._card2:
if self.isGameOver():
self._quit = True
else:
print("Not an identical pair. Found " + str(self._card1) + " at (" + str(self._coord1[0]) + "," +str(self._coord1[1]) + ") and " + str(self._card2) + " at (" + str(self._coord2[0]) + "," + str(self._coord2[1]) + ")")
self._card1._face = 0
self._card2._face = 0'''
def guessFirst(self):
self._coord1 = input("Enter the coordinates for the first card ").split(' ')
self._coord1 = list(map(int, self._coord1))
if (self._coord1[0]-1 <= self._columns) and (self._coord1[1]-1 <= self._rows) and (self._coord1[0]-1 >= 0) and (self._coord1[1]-1 >= 0):
output = self._board[self._coord1[0]-1][self._coord1[1]-1]
else:
output = "***Invalid coordinates! Try again.***"
return output
def guessSecond(self):
self._coord1 = input("Enter the coordinates for the second card ").split(' ')
self._coord1 = list(map(int, self._coord1))
if (self._coord1[0]-1 <= self._columns) and (self._coord1[1]-1 <= self._rows) and (self._coord1[0]-1 >= 0) and (self._coord1[1]-1 >= 0):
output = self._board[self._coord1[0]-1][self._coord1[1]-1]
else:
output = "***Invalid coordinates! Try again.***"
return output
def play(self):
self.populateBoard()
while self._quit == False:
self.displayBoard()
self._card1 = self.guessFirst()
while self._card1 == "***Invalid coordinates! Try again.***":
print("Coordinates outside gameboard. Please give coordinates on the board")
self._card1 = self.guessFirst()
self._card1._face = 1
self._card2 = self.guessSecond()
while self._card2 == "***Invalid coordinates! Try again.***" or self._card2._face == 1:
if self._card2 == "***Invalid coordinates! Try again.***":
print("Coordinates outside gameboard. Please give coordinates on the board")
else:
print("you have already selected that card. give coordinates for a facedown card")
self._card2 = self.guessSecond()
self._card2._face = 1
self.displayBoard()
if self._card1 == self._card2:
if self.isGameOver():
self._quit = True
else:
self._card1._face = 0
self._card2._face = 0
def main():
while True:
# Force user to enter valid value for number of rows
while True:
rows = input("Enter number of rows ")
if rows.isdigit() and ( 1 <= int(rows) <= 9):
rows = int(rows)
break
else:
print (" ***Number of rows must be between 1 and 9! Try again.***")
# Adding *** and indenting error message makes it easier for the user to see
# Force user to enter valid value for number of columns
while True:
columns = input("Enter number of columns ")
if columns.isdigit() and ( 1 <= int(columns) <= 9):
columns = int(columns)
break
else:
print (" ***Number of columns must be between 1 and 9! Try again.***")
if rows * columns % 2 == 0:
break
else:
print (" ***The value of rows X columns must be even. Try again.***")
game = Game(rows, columns)
game.play()
if __name__ == "__main__":
main()
最佳答案
您似乎混淆了行和列。在 populateBoard
中,您使用 _board
的第一个坐标作为行,第二个坐标作为列。在 guessFirst
中,您根据列数检查第一个坐标,根据行数检查第二个坐标。
关于python - Python内存匹配游戏中出现"List index out of range"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46840900/
使用sed和/或awk,仅在行包含字符串“ foo”并且行之前和之后的行分别包含字符串“ bar”和“ baz”时,我才希望删除行。 因此,对于此输入: blah blah foo blah bar
例如: S1: "some filename contains few words.txt" S2:“一些文件名包含几个单词 - draft.txt” S3:“一些文件名包含几个单词 - 另一个 dr
我正在尝试处理一些非常困惑的数据。我需要通过样本 ID 合并两个包含不同类型数据的大数据框。问题是一张表的样本 ID 有许多不同的格式,但大多数都包含用于匹配其 ID 中某处所需的 ID 字符串,例如
我想在匹配特定屏幕尺寸时显示特定图像。在这种情况下,对于 Bootstrap ,我使用 col-xx-## 作为我的选择。但似乎它并没有真正按照我认为应该的方式工作。 基本思路,我想显示一种全屏图像,
出于某种原因,这条规则 RewriteCond %{REQUEST_FILENAME} !-f RewriteCond %{REQUEST_FILENAME} !-d RewriteRule ^(.*
我想做类似的东西(Nemerle 语法) def something = match(STT) | 1 with st= "Summ" | 2 with st= "AVG" =>
假设这是我的代码 var str="abc=1234587;abc=19855284;abc=1234587;abc=19855284;abc=1234587;abc=19855284;abc=123
我怎样才能得到这个字符串的数字:'(31.5393701, -82.46235569999999)' 我已经在尝试了,但这离解决方案还很远:) text.match(/\((\d+),(\d+)\)/
如何去除输出中的逗号 (,)?有没有更好的方法从字符串或句子中搜索 url。 alert(" http://www.cnn.com df".match(/https?:\/\/([-\w\.]+
a = ('one', 'two') b = ('ten', 'ten') z = [('four', 'five', 'six'), ('one', 'two', 'twenty')] 我正在尝试
我已经编写了以下代码,我希望用它来查找从第 21 列到另一张表中最后一行的值,并根据这张表中 A 列和另一张表中 B 列中的值将它们返回到这张表床单。 当我使用下面的代码时,我得到一个工作表错误。你能
我在以下结构中有两列 A B 1 49 4922039670 我已经能够评估 =LEN(A1)如2 , =LEFT(B1,2)如49 , 和 =LEFT(B1,LEN(A1)
我有一个文件,其中一行可以以 + 开头, -或 * .在其中一些行之间可以有以字母或数字(一般文本)开头的行(也包含这些字符,但不在第 1 列中!)。 知道这一点,设置匹配和突出显示机制的最简单方法是
我有一个数据字段文件,其中可能包含注释,如下所示: id, data, data, data 101 a, b, c 102 d, e, f 103 g, h, i // has to do with
我有以下模式:/^\/(?P.+)$/匹配:/url . 我的问题是它也匹配 /url/page ,如何忽略/在这个正则表达式中? 该模式应该: 模式匹配:/url 模式不匹配:/url/page 提
我有一个非常庞大且复杂的数据集,其中包含许多对公司的观察。公司的一些观察是多余的,我需要制作一个键来将多余的观察映射到一个单独的观察。然而,判断他们是否真的代表同一家公司的唯一方法是通过各种变量的相似
我有以下 XML A B C 我想查找 if not(exists(//Record/subRecord
我制作了一个正则表达式来验证潜在的比特币地址,现在当我单击报价按钮时,我希望根据正则表达式检查表单中输入的值,但它不起作用。 https://jsfiddle.net/arkqdc8a/5/ var
我有一些 MS Word 文档,我已将其全部内容转移到 SQL 表中。 内容包含多个方括号和大括号,例如 [{a} as at [b],] {c,} {d,} etc 我需要进行检查以确保括号平衡/匹
我正在使用 Node.js 从 XML 文件读取数据。但是当我尝试将文件中的数据与文字进行比较时,它不匹配,即使它看起来相同: const parser: xml2js.Parser = new
我是一名优秀的程序员,十分优秀!