В качестве упражнения я пытался построить игру на языке не-GUI в Python.Пока что пользователь может ввести размер платы (4х4,5х5 и т. Д.).Появляется «массив» букв, и затем пользователь может ввести слово, которое он считает допустимым.
Я хотел проверить правильность введенного слова, используя рекурсивную функцию.На маленьких досках моё решение вроде бы работает нормально.Однако на больших досках слова с похожими запусками и несколькими путями не регистрируются.У меня такое ощущение, что это потому, что последняя часть моей функции не способна отступить достаточно далеко, если текущий путь заканчивается без поиска правильного слова.
Вот что у меня так далеко:
def isAdjacent(word, wordLetter, possibleStarts, arrayDict, currWord, start):
#'word' is the word entered. 'wordLetter' is the current letter being looked for.
#'possibleStarts' is a list of tuples of the possible starting locations and subsequent positions of each found letter.
#'arrayDict' is a dictionary associating each position ((0,1), etc) with a game letter.
#'currWord' is used to check whether or not a word has been found.
#'start' is the tuple in possibleStarts that should be used.
if currWord == word:
return 1
x = possibleStarts[start][0]
y = possibleStarts[start][1]
arrayDict[x,y] = 0
optionsList = [(x - 1, y - 1), (x - 1, y), (x - 1, y + 1), (x, y - 1), (x, y + 1), (x + 1, y - 1), (x + 1, y), (x + 1, y + 1)]
newStarts = []
count = 0
count2 = 0
for option in optionsList:
count += 1
if option in arrayDict:
if arrayDict[option] == word[wordLetter]:
if count2 < 1:
currWord += word[wordLetter]
arrayDict[option] = 0
count2 += 1
newStarts.append(option)
if count == 8 and newStarts:
return isAdjacent(word, wordLetter + 1, newStarts, arrayDict, currWord, start)
try:
if currWord != word:
if wordLetter > 2:
return isAdjacent(word, wordLetter - 1, possibleStarts, arrayDict, currWord[:-1], start - 1)
else:
return isAdjacent(word, wordLetter, possibleStarts, arrayDict, currWord, start - 1)
except:
pass
Я считаю, что, по крайней мере, часть проблемы заключается в блоке try в конце функции.Это работает, если слово не слишком длинное или если не слишком много возможностей.Например, попытка найти «сырье» в следующем не будет работать, даже если он там есть:
W T S V
A X A H
S R T S
A B A W
Я уверен, что это можно сделать с помощью довольно простой рекурсивной функции, но после многихчасы, я потерян.О, я бы предпочел не генерировать все возможные слова заранее.Целью этого было использование рекурсии для поиска введенного слова.
Любая помощь очень ценится!