TheAlgorithms-Python/ciphers/caesar_cipher.py

68 lines
2.1 KiB
Python
Raw Normal View History

def encrypt(input_string: str, key: int) -> str:
result = ""
for x in input_string:
if not x.isalpha():
result += x
elif x.isupper():
result += chr((ord(x) + key - 65) % 26 + 65)
elif x.islower():
result += chr((ord(x) + key - 97) % 26 + 97)
return result
2018-05-28 21:46:02 +08:00
def decrypt(input_string: str, key: int) -> str:
result = ""
for x in input_string:
if not x.isalpha():
result += x
elif x.isupper():
result += chr((ord(x) - key - 65) % 26 + 65)
elif x.islower():
result += chr((ord(x) - key - 97) % 26 + 97)
return result
2018-05-28 21:46:02 +08:00
2019-10-05 13:14:13 +08:00
def brute_force(input_string: str) -> None:
2018-05-28 21:46:02 +08:00
key = 1
result = ""
2018-05-29 05:25:48 +08:00
while key <= 94:
for x in input_string:
2018-05-28 21:46:02 +08:00
indx = (ord(x) - key) % 256
if indx < 32:
indx = indx + 95
result = result + chr(indx)
print(f"Key: {key}\t| Message: {result}")
result = ""
2018-05-28 21:46:02 +08:00
key += 1
return None
2016-07-29 15:00:38 +08:00
2016-08-03 01:46:55 +08:00
def main():
2018-05-28 21:46:02 +08:00
while True:
print(f'{"-" * 10}\n Menu\n{"-" * 10}')
print(*["1.Encrpyt", "2.Decrypt", "3.BruteForce", "4.Quit"], sep="\n")
2018-10-21 03:45:08 +08:00
choice = input("What would you like to do?: ")
2019-10-05 13:14:13 +08:00
if choice not in ["1", "2", "3", "4"]:
print("Invalid choice, please enter a valid choice")
2019-10-05 13:14:13 +08:00
elif choice == "1":
input_string = input("Please enter the string to be encrypted: ")
key = int(input("Please enter off-set between 0-25: "))
if key in range(1, 95):
print(encrypt(input_string.lower(), key))
2019-10-05 13:14:13 +08:00
elif choice == "2":
input_string = input("Please enter the string to be decrypted: ")
key = int(input("Please enter off-set between 1-94: "))
2019-10-05 13:14:13 +08:00
if key in range(1, 95):
print(decrypt(input_string, key))
2019-10-05 13:14:13 +08:00
elif choice == "3":
input_string = input("Please enter the string to be decrypted: ")
brute_force(input_string)
2018-05-28 21:46:02 +08:00
main()
2019-10-05 13:14:13 +08:00
elif choice == "4":
print("Goodbye.")
break
2019-10-05 13:14:13 +08:00
if __name__ == "__main__":
main()