mirror of
https://github.com/TheAlgorithms/Python.git
synced 2024-12-18 17:20:16 +00:00
b7f13d991c
* Travis CI: Add type checking with mypy * Create requirements.txt * script: mypy --ignore-missing-stubs=cv2,numpy . * Delete requirements.txt * script: mypy --ignore-missing-imports . * Run doctests * Disable doctest -v other/detecting_english_programmatically.py * Pytest * No | * pytest || true * Run black doctest flake8 mypy pytest * after_success: Build Directory.md * Typo in filename: Dictionary.txt --> dictionary.txt' Discovered via doctest run in #964 * python -m doctest -v * pip install black flake8 mypy pytest * pytest --doctest-glob='*.py' * pytest --doctest-modules * pytest --doctest-modules ./sorts * pytest --doctest-modules ./ciphers ./other ./searches ./sorts ./strings || true * if __name__ == "__main__": * if __name__ == "__main__": * if __name__ == '__main__': * if __name__ == '__main__': * if __name__ == '__main__': * Create requirements.txt * Update requirements.txt * if __name__ == "__main__": * Lose the doctests * if __name__ == '__main__': * Remove print-a-tuple * doctest: Added missing spaces * Update tabu_search.py * The >>> are not doctests so change to >>) * Travis CI: Run black, doctest, flake8, mypy, and pytest * Link to the separate DIRECTORY.md file * Update README.md
66 lines
1.9 KiB
Python
66 lines
1.9 KiB
Python
def encrypt(strng, key):
|
|
encrypted = ''
|
|
for x in strng:
|
|
indx = (ord(x) + key) % 256
|
|
if indx > 126:
|
|
indx = indx - 95
|
|
encrypted = encrypted + chr(indx)
|
|
return encrypted
|
|
|
|
|
|
def decrypt(strng, key):
|
|
decrypted = ''
|
|
for x in strng:
|
|
indx = (ord(x) - key) % 256
|
|
if indx < 32:
|
|
indx = indx + 95
|
|
decrypted = decrypted + chr(indx)
|
|
return decrypted
|
|
|
|
def brute_force(strng):
|
|
key = 1
|
|
decrypted = ''
|
|
while key <= 94:
|
|
for x in strng:
|
|
indx = (ord(x) - key) % 256
|
|
if indx < 32:
|
|
indx = indx + 95
|
|
decrypted = decrypted + chr(indx)
|
|
print("Key: {}\t| Message: {}".format(key, decrypted))
|
|
decrypted = ''
|
|
key += 1
|
|
return None
|
|
|
|
|
|
def main():
|
|
while True:
|
|
print('-' * 10 + "\n**Menu**\n" + '-' * 10)
|
|
print("1.Encrpyt")
|
|
print("2.Decrypt")
|
|
print("3.BruteForce")
|
|
print("4.Quit")
|
|
choice = input("What would you like to do?: ")
|
|
if choice not in ['1', '2', '3', '4']:
|
|
print ("Invalid choice, please enter a valid choice")
|
|
elif choice == '1':
|
|
strng = input("Please enter the string to be encrypted: ")
|
|
key = int(input("Please enter off-set between 1-94: "))
|
|
if key in range(1, 95):
|
|
print (encrypt(strng.lower(), key))
|
|
elif choice == '2':
|
|
strng = input("Please enter the string to be decrypted: ")
|
|
key = int(input("Please enter off-set between 1-94: "))
|
|
if key in range(1,95):
|
|
print(decrypt(strng, key))
|
|
elif choice == '3':
|
|
strng = input("Please enter the string to be decrypted: ")
|
|
brute_force(strng)
|
|
main()
|
|
elif choice == '4':
|
|
print ("Goodbye.")
|
|
break
|
|
|
|
|
|
if __name__ == '__main__':
|
|
main()
|