Compare commits

...

6 Commits

Author SHA1 Message Date
Srivaishnavi Yaddanapudi
f577a1966d
Merge 3a98cdab6e into e3bd7721c8 2024-11-17 17:51:30 +05:30
Srivaishnavi Yaddanapudi
3a98cdab6e
Change N into lowercase 2024-10-29 17:34:37 +05:30
Srivaishnavi Yaddanapudi
92d58b7109
Add `.split 2024-10-29 17:21:43 +05:30
Srivaishnavi Yaddanapudi
2bef9b9cb3
Update documentation 2024-10-29 17:06:56 +05:30
Srivaishnavi Yaddanapudi
5efef35d8d
Add input validation and change function name to apply_rot13 2024-10-29 17:04:58 +05:30
Srivaishnavi Yaddanapudi
4879a46be1
Fix number of rotations N as 13 (Resolves TheAlgorithms#12306) 2024-10-29 16:52:40 +05:30

View File

@ -1,14 +1,20 @@
def dencrypt(s: str, n: int = 13) -> str:
def apply_rot13(s: str) -> str:
"""
https://en.wikipedia.org/wiki/ROT13
Performs a special reversible case of the Caesar cipher.
Rotates a text by 13 letters.
Also see: https://en.wikipedia.org/wiki/ROT13
Example usage:
>>> msg = "My secret bank account number is 173-52946 so don't tell anyone!!"
>>> s = dencrypt(msg)
>>> s = apply_rot13(msg)
>>> s
"Zl frperg onax nppbhag ahzore vf 173-52946 fb qba'g gryy nalbar!!"
>>> dencrypt(s) == msg
>>> apply_rot13(s) == msg
True
"""
if not isinstance(s, str):
return "The input must be a string. Please try again."
n = 13
out = ""
for c in s:
if "A" <= c <= "Z":
@ -21,12 +27,12 @@ def dencrypt(s: str, n: int = 13) -> str:
def main() -> None:
s0 = input("Enter message: ")
s0 = input("Enter message: ").strip()
s1 = dencrypt(s0, 13)
s1 = apply_rot13(s0)
print("Encryption:", s1)
s2 = dencrypt(s1, 13)
s2 = apply_rot13(s1)
print("Decryption:", s2)