将mp定义为行列都与mf相同的矩阵,i行的元素都是从0-len(mf[i])
时间: 2024-03-12 10:45:28 浏览: 18
如果要将`mp`定义为行列都与`mf`相同的矩阵,且第`i`行的元素都是从`0`到`len(mf[i])`的整数,可以按照以下方式生成`mp`:
```python
mp = [[j for j in range(len(mf[i]))] for i in range(len(mf))]
```
这样生成的`mp`是一个和`mf`同样大小的矩阵,每个位置上的元素都是从`0`到对应`f`子列表的长度减一的整数。具体的`mp`矩阵如下所示:
```python
mp = [
[0, 1, 2, 3, 4, 5],
[0, 1, 2, 3, 4, 5],
[0, 1, 2],
[0, 1, 2, 3, 4],
[0, 1, 2, 3, 4],
[0, 1, 2, 3, 4, 5]
]
```
可以看到,每行的元素都是从`0`到对应`f`子列表的长度减一的整数。
相关问题
将mp定义为与mf相似的矩阵
如果要将`mp`定义为与`mf`相似的矩阵,可以将`mp`的每个元素赋值为对应位置上的`f`子列表中的元素。具体的代码如下所示:
```python
mp = [ [f1[i], f2[j], f3[k], f4[l], f5[m], f6[n]]
for i in range(len(f1))
for j in range(len(f2))
for k in range(len(f3))
for l in range(len(f4))
for m in range(len(f5))
for n in range(len(f6))]
```
这样生成的`mp`就是一个包含了所有可能排列的列表,可以与`mf`进行比较。
for p in itertools.product(*(itertools.permutations(range(len(mf[i]))) for i in range(6))): for i in range(6): for j in range(len(mf[i])): print(p[i][j], end=" ") break将这段代码改写为,使mp为mf的排列
可以将for循环的第一行修改为以下代码:
```
for p in itertools.product(*[itertools.permutations(mf[i]) for i in range(6)]):
```
这样就能将mp改为mf的排列了。修改后的完整代码如下:
```
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_m = [sorted_letters[:8], sorted_letters[8:16], sorted_letters[-10:]] # high 8 middle 8 low 10
f1 = ['e'] # >10%
f2 = ['a', 'i', 'r', 't', 'o', 'n']
f3 = ['s', 'l', 'c']
f4 = ['u', 'p', 'm', 'd', 'h']
f5 = ['g', 'b', 'y', 'f', 'v']
f6 = ['w', 'k', 'x', 'z', 'q', 'j'] # <1%
mf = [f1, f2, f3, f4, f5, f6]
mp = [[iter(range(len(mf[i]))) for j in range(len(mf[i]))] for i in range(len(mf))]
flag = True
while(flag):
key = {}
for p in itertools.product(*[itertools.permutations(mf[i]) for i in range(6)]):
for i in range(6):
for j in range(len(mf[i])):
print(p[i][j], end=" ")
break
for i in range(6):
for j in range(len(mf[i])):
index = next(mp[i][j])
key.update({most_common_letters_m[i][index]: mf[i][j]})
decrypted_text = decrypt(cipher_text, key)
if is_plaintext(decrypted_text, words):
flag=False
return key
```