凯撒密码加密算法
编写一个凯撒密码加密程序,接收用户输入的文本和密钥k,对明文中的字母a-z和字母A-Z替换为其后第k个字母。
输入格式:
接收两行输入,第一行为待加密的明文,第二行为密钥k。
输出格式:
输出加密后的密文。
输入样例:
在这里给出一组输入。例如:
Hello World!
3
输出样例:
在这里给出相应的输出。例如:
Khoor Zruog!
str = input()
k = eval(input())
ans = ''
for i in str:
if i.isalpha():
a = 'a' if i.islower() else 'A'
ind = (ord(i) - ord(a) + k) % 26 + ord(a)
ans += chr(ind)
else:
ans += i
print(ans)
加密解密
代码
op = eval(input("请选择您要进行的操作,0表示加密,1表示解密"))
str = input("请输入您要进行操作的字符串")
k = eval(input("请输入移动的位数"))
ans = ''
if op == 0:
for i in str:
if i.isalpha():
a = 'a' if i.islower() else 'A'
ind = (ord(i) - ord(a) + k) % 26 + ord(a)
ans += chr(ind)
else:
ans += i
else:
for i in str:
if i.isalpha():
a = 'a' if i.islower() else 'A'
ind = (ord(i) - ord(a) - k) % 26 + ord(a)
ans += chr(ind)
else:
ans += i
print(ans)
运行效果
加密
解密
汉字加密解密
问题
如何设计汉字的凯撒加密算法?
·子问题:汉字的Unicode编码范围是?
·子问题:在上述编码范围内,共多少汉字?
基本汉字
代码
op = eval(input("请选择您要进行的操作,0表示加密,1表示解密"))
que = input("请输入您要进行操作的汉字")
k = eval(input("请输入移动的位数"))
ans = ''
if op == 0:
for i in que:
# 编码unicode,解码成utf-8,字符串前面的\u替换掉
ind = i.encode('unicode_escape').decode("utf-8").replace("\\u", "")
ind = (int(ind, 16) - 0x4E00 + k) % 20902 + 0x4E00
ans += chr(ind)
else:
for i in que:
ind = i.encode('unicode_escape').decode("utf-8").replace("\\u", "")
ind = (int(ind, 16) - 0x4E00 - k) % 20902 + 0x4E00
ans += chr(ind)
print(ans)
运行结果
样例
假设我们选择的输入为:
丘丙从东丝
则在加密过程中获得的输出:
丞丟仔丢丣