python - 自动解决单词搜索 (4x4)
问题描述
我尝试制作一个单词搜索求解器,我不是程序员,但我使用 python 来自动化我的日常小任务:) 在这个场合,我想给我的祖母一个惊喜,让她知道一台计算机可以解决她的报纸单词自动搜索,这是 4x4,可以向任何方向移动到附近的单元格(不仅是对角线,垂直和水平,如果单元格靠近是有效的)这是我制作的代码
到目前为止,我已经设法找到与字母匹配的单词,但我不知道如何教你只取附近有单元格的单词,我非常感谢你的帮助
注意:文件“twl06.txt”只是一个带有单词的字典。
更新:对于附近的单元格,我的意思是单词不是以简单的直线形成的,因为它们在单元格旁边时有效
#For example: niosijmcyhtedfio
palabra2=input("Insertar letras: ")
print ("")
print ("")
f=open("twl06.txt")
libro=f.read()
print ((palabra2[0]), (""),(palabra2[1]), (""),(palabra2[2]), (""),(palabra2[3]))
print ((palabra2[4]), (""),(palabra2[5]), (""),(palabra2[6]), (""),(palabra2[7]))
print ((palabra2[8]), (""),(palabra2[9]), (""),(palabra2[10]), (""),(palabra2[11]))
print ((palabra2[12]), (""),(palabra2[13]), (""),(palabra2[14]), (""),(palabra2[15]))
print ("")
print ("")
#palabra2 es con repeticiones
#palabra es sin repeticiones
palabra = ("".join(set(palabra2)))
comparacion = []
with open("twl06.txt") as f:
for line in f:
lista1 = (list(palabra))
lista2 = (list(line.rstrip('\n')))
comparacion = []
for item in lista1:
if item in lista2:
comparacion.append(item)
if len(comparacion) == 3:
if (len(lista2)) == 3:
print (" ".join(str(x) for x in lista2))
comparacion = []
if len(comparacion) == 4:
if (len(lista2)) == 4:
print (" ".join(str(x) for x in lista2))
comparacion = []
if len(comparacion) == 5:
if (len(lista2)) == 5:
print (" ".join(str(x) for x in lista2))
comparacion = []
if len(comparacion) == 6:
if (len(lista2)) == 6:
print (" ".join(str(x) for x in lista2))
comparacion = []
if len(comparacion) == 7:
if (len(lista2)) == 7:
print (" ".join(str(x) for x in lista2))
comparacion = []
f.close()
解决方案
如果您将字段定义为数组数组(出于说明目的而牺牲了正确的格式):
field= [
[
[entry1],[entry2],[entry3]
],[
[entry4],[entry5],[entry6]
],[
[entry7],[entry8],[entry9]
]
]
您的字段将按如下方式组织:
[0][0] | [0][1] | [0][2]
------------------------
[1][0] | [1][1] | [2][2]
------------------------
[2][0] | [2][1] | [2][2]
所以相邻的单元格field[m][n]
可以通过
i = m-1
while i < m+1 :
j=n-1
while j < n+1:
if (i = m && j = n):
continue #skip the cell itself
doSomething(field[i][j])
j = j+1
i = i+1