def guess_key3(cipher_text, word1, word2, word3): #变了点 letter_frequency = get_letter_frequency(cipher_text.lower()) excluded_letters = [letter for letter in letter_frequency.keys() if letter_frequency[letter] == 0] sorted_letters = sorted([letter for letter in letter_frequency.keys() if letter_frequency[letter] > 0], key=lambda x: letter_frequency[x], reverse=True) print("Excluded letters:", excluded_letters) print() f1 = ['a', 'i', 'r'] f2 = ['t', 'o', 'n'] f3 = ['s', 'l', 'c'] f4 = ['u', 'p', 'm', 'd', 'h'] f5 = ['g', 'b', 'y', 'f'] f6 = ['v', 'w','k'] f7 = ['x', 'z', 'q', 'j'] mf = [f6, f5, f4, f3, f2, f1] key = {sorted_letters[0]: 'e'} most_common_letters_m = [sorted_letters[19:22],sorted_letters[15:19] ,sorted_letters[10:15] ,sorted_letters[7:10] ,sorted_letters[4:7], sorted_letters[1:4]] c1 = 0.05 for i1 in range(5): lk1=len(key) key1 = check3(cipher_text, word1, word2, word3, most_common_letters_m, sorted_letters, mf, f7, lk1, key, c1, i1) key.update(key1) del mf[-1] del most_common_letters_m[-1] print(key) print() c1+=0.1 return key def check3(cipher_text, word1, word2, word3, most_common_letters_m, sorted_letters, mf, f7, lk1, key, c1, i1): mp = [[j for j in range(len(mf[i]))] for i in range(len(mf))] row_permutations = [itertools.permutations(row) for row in mp] matrix_permutations = itertools.product(*row_permutations) for permutation in matrix_permutations: for i in range(len(mp)): for j in range(len(mp[i])): key[most_common_letters_m[i][permutation[i][j]]] = mf[i][j] if len(key) < len(sorted_letters): for i, val in enumerate(f7): key[sorted_letters[i]] = val decrypted_text = decrypt(cipher_text, key) k1 = is_plaintext3(decrypted_text, word1, word2 ,word3) #k2 = k1 if k1 > k2 else k2 if( k1 > c1): key1 = dict(list(key)[lk1:len(mp[i1])+lk1]) return key1 def is_plaintext3(text, word1, word2 ,word3): words_found = 0 for word in text.split(): if word.lower() in word1: words_found += 10 if word.lower() in word2: words_found += 3 if word.lower() in word3: words_found += 1 return (words_found / len(text.split())) def decrypt(cipher_text, key): mapping_dict = str.maketrans(key) return cipher_text.translate(mapping_dict)有什么问题
时间: 2024-04-07 17:28:23 浏览: 98
这段代码中存在一些问题,可能会影响其功能:
1. 在 check3 函数中,如果没有找到有效的解密密钥,则没有返回值,因此当函数结束时会返回 None。这可能会导致 guess_key3 函数出现异常或错误,因为它不会检查 check3 的返回值是否为 None。
2. 在 check3 函数中,如果找到了有效的解密密钥,则直接返回了一个部分密钥字典。这意味着在 guess_key3 函数中,如果在第一次调用 check3 之后找到了有效的密钥,则只有部分密钥会被添加到密钥字典中。这可能会导致后续调用 check3 函数时出现问题。
3. 在 check3 函数中,如果找到了有效的解密密钥,则直接返回了该密钥字典的一部分,而不是完整的密钥字典。因此,在 guess_key3 函数中,部分密钥字典将与新的部分密钥字典合并,这可能会导致部分密钥重复,从而导致解密出现问题。
4. 在 check3 函数中,如果找到的有效解密密钥的分数小于当前最佳分数,则不会返回该密钥。这可能会导致 guess_key3 函数返回一个不完整的密钥字典,因为它假设 check3 函数总是返回一个有效的密钥字典。
5. 在 is_plaintext3 函数中,如果文本中有多个单词,它将只计算找到的单词数量的总和,而不是每个单词的分数。这可能会导致分数不准确,从而导致代码选择错误的密钥字典。
需要注意的是,这只是我在快速查看代码时注意到的一些问题,可能还存在其他问题。
相关问题
def guess_key(cipher_text, words): letter_frequency = get_letter_frequency(cipher_text.lower()) sorted_letters = sorted(letter_frequency.keys(), key=lambda x: letter_frequency[x], reverse=True) most_common_letters = sorted_letters[:6] for i in range(len(most_common_letters)): for j in range(i+1, len(most_common_letters)): for k in range(j+1, len(most_common_letters)): key = {most_common_letters[i]: 'e', most_common_letters[j]: 't', most_common_letters[k]: 'a'} decrypted_text = decrypt(cipher_text, key) if is_plaintext(decrypted_text, words): return key
这段代码实现了一个猜测密钥的算法,它接受两个参数:`cipher_text`(密文)和 `words`(单词列表),并返回一个字典类型的对象,表示猜测的密钥。
算法的实现原理是首先统计密文中每个字母出现的频率,然后按照频率从高到低排序,选取出现频率最高的 6 个字母作为备选字母。接下来,对于这 6 个字母中的任意 3 个字母,猜测它们分别对应明文中的 'e'、't'、'a' 三个字母,得到一个可能的密钥。然后使用这个密钥解密密文,判断解密后的明文是否合法,如果合法,则返回这个密钥。
需要注意的是,这个算法可能会产生错误的猜测,因为只是根据字母频率进行猜测,没有考虑其他语言特征(如单词长度、语法结构等)。因此,猜测的密钥不一定是正确的,需要进一步进行验证和调整。
def guess_key1(cipher_text, words): letter_frequency = get_letter_frequency(cipher_text.lower()) sorted_letters = sorted(letter_frequency.keys(), key=lambda x: letter_frequency[x], reverse=True) # paixu most_common_letters = sorted_letters[:6] # first 6 for i in range(len(most_common_letters)): for j in range(i+1, len(most_common_letters)): for k in range(j+1, len(most_common_letters)): key = {most_common_letters[i]: 'e', most_common_letters[j]: 't', most_common_letters[k]: 'a'} # key = {'n': 'e', 'o': 't', 's': 'a'} .... decrypted_text = decrypt(cipher_text, key) if is_plaintext(decrypted_text, words): return key def decrypt(cipher_text, key): mapping_dict = str.maketrans(key) return cipher_text.translate(mapping_dict) def is_plaintext(text, words): words_found = 0 for word in text.split(): if word.lower() in words: words_found += 1 return (words_found / len(text.split())) > 0.001 其中key并没有替换掉所有字母,修改
可以尝试将key字典中没有替换的字母的值设置为出现频率最高的字母,即将如下代码:
```
key = {most_common_letters[i]: 'e', most_common_letters[j]: 't', most_common_letters[k]: 'a'}
```
修改为:
```
key = {most_common_letters[i]: 'e', most_common_letters[j]: 't', most_common_letters[k]: 'a'}
for letter in sorted_letters:
if letter not in key:
key[letter] = sorted_letters[0]
```
这样就可以保证key字典中所有字母都被替换了,并且未被替换的字母的值为出现频率最高的字母。
阅读全文