Я пытаюсь расшифровать шифр Цезаря с помощью грубой силы. Я могу довольно легко что-то зашифровать, а затем я хочу, чтобы программа расшифровывала сообщение с помощью грубой силы. Я хочу, чтобы python распечатал все 26 значений сдвига зашифрованного сообщения. Это мой код:
message = input("What message do you want to use: ")
shiftValue = int(input("What would you like to shift the message by: "))
encryptedMsg = ""
for character in message:
if character.isalpha() == True:
if character == character.lower():
x = ord(character) - 97
x += shiftValue
x = x % 26
encryptedMsg += chr(x + 97)
else:
x = ord(character) - 65
x += shiftValue
x = x % 26
encryptedMsg += chr(x+65)
else:
encryptedMsg += character
print(encryptedMsg)
def decrypt(encryptedMsg):
i = 0
shiftValue = 0
while i < 26:
attempt = ""
for char in encryptedMsg:
if char.isalpha() == True:
x = ord(char) - 97
x = x + shiftValue
x = x % 26
attempt += chr(x+97)
else:
attempt += char
print(attempt)
i += 1
shiftValue += 1
decrypt(encryptedMsg)
Как только я запустил это, мне дается следующий код в оболочке python. Допустим, переменная сообщения - «Меня зовут Даниэль», и я использую shiftValue, равный 2. Вот что печатается:
i
ib
ib
ib s
ib sg
ib sgt
ib sgtm
ib sgtm
ib sgtm s
ib sgtm sd
ib sgtm sd
ib sgtm sd k
ib sgtm sd ko
ib sgtm sd koc
ib sgtm sd kocy
ib sgtm sd kocyv
ib sgtm sd kocyvd
z
zs
zs
zs j
zs jx
zs jxk
zs jxkd
zs jxkd
zs jxkd j
zs jxkd ju
zs jxkd ju
zs jxkd ju b
zs jxkd ju bf
zs jxkd ju bft
zs jxkd ju bftp
zs jxkd ju bftpm
zs jxkd ju bftpmu