这里是我的工作代码,我试图找到方法使其更快地找到有效的单词,我正在考虑可能为每个单词做单独的词典列表,你觉得怎么样?需要帮助使排列更快
import random
import itertools
file_name='words.txt'
def load_words():
try:
f=open(file_name,'r')
str1=f.read()
f.close()
except:
print('Problem opening the file',file_name)
list1=[]
list1=str1.split()
return(list1)
def is_valid(str1,list1):
valid=False
if str1 in list1:
valid=True
return valid
def generate(words,letters):
answers=[]
for length in range(2,len(letters)+1):
for x in itertools.permutations(letters,length):
word=''
for let in x:
word+=let
if is_valid(word.upper(),words):
answers.append(word)
print(word)
print(answers)
def main():
words=load_words()
letters = input('Enter your letters')
answers = generate(words,letters)
main()
感谢您的评论,我不觉得它有什么快速的,如果你拿着这个程序并运行7个以上的字母输入,你会发现它很慢。 –
它比列表快一个数量级。 –
@BrandonRutledge:不要依赖'感觉'来优化程序。使用'timeit'模块来测试这些假设。 (http://docs.python.org/library/timeit.html) – Kylotan