mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
7f04e5cd34
* spelling corrections * review * improved documentation, removed redundant variables, added testing * added type hint * camel case to snake case * spelling fix * review * python --> Python # it is a brand name, not a snake * explicit cast to int * spaces in int list * "!= None" to "is not None" * Update comb_sort.py * various spelling corrections in documentation & several variables naming conventions fix * + char in file name * import dependency - bug fix Co-authored-by: John Law <johnlaw.po@gmail.com>
31 lines
805 B
Python
31 lines
805 B
Python
import random
|
|
|
|
|
|
class Onepad:
|
|
def encrypt(self, text):
|
|
"""Function to encrypt text using pseudo-random numbers"""
|
|
plain = [ord(i) for i in text]
|
|
key = []
|
|
cipher = []
|
|
for i in plain:
|
|
k = random.randint(1, 300)
|
|
c = (i + k) * k
|
|
cipher.append(c)
|
|
key.append(k)
|
|
return cipher, key
|
|
|
|
def decrypt(self, cipher, key):
|
|
"""Function to decrypt text using pseudo-random numbers."""
|
|
plain = []
|
|
for i in range(len(key)):
|
|
p = int((cipher[i] - (key[i]) ** 2) / key[i])
|
|
plain.append(chr(p))
|
|
plain = "".join([i for i in plain])
|
|
return plain
|
|
|
|
|
|
if __name__ == "__main__":
|
|
c, k = Onepad().encrypt("Hello")
|
|
print(c, k)
|
|
print(Onepad().decrypt(c, k))
|