完成下面的凯撒加密算法,将明文输出为密文(移位次数由用户决定)。函数名:Caesar_cipher(n,rawstr)。其中,n表示移位数量,rawstr表示用户输入的原文。
def Caesar_cipher(n,rawstr):
'''
本函数中,不可以使用ord,char等函数。在程序中已经给了字符列表,要求使用列表来完成置换。思路是:先判断字符串中的字符是否在列表中,如果在,则移位n,如果不在,则原样输出,请完成下列程序 '''
alpha = list('abcdefghijklmnopqrstuvwxyz')
在这里完善程序,上下文不许动
str_1 =input('请输入原文')
n = int(input('请输入你所需要移位的数值'))
cipher =Caesar_cipher(n,str_1)
print(f'移位{n}后,密文为{cipher}')
字符串的解法:
alpha = list('abcdefghijklmnopqrstuvwxyz')
def Caesar_cipher(n,str_1):
alpha2 = alpha[n:]+alpha[:n]
table = str.maketrans(''.join(alpha), ''.join(alpha2))
str_2 = ''
for i in str_1:
if i in alpha:
str_2 += i.translate(table)
else:
str_2 += i
return str_2
字典的解法:
alpha = list('abcdefghijklmnopqrstuvwxyz')
def Caesar_cipher(n,str_1):
alpha2 = alpha[n:]+alpha[:n]
table = dict(zip(alpha,alpha2))
str_2=''
for i in str_1:
if i in alpha:
str_2+=table[i]
else:
str_2+=i
return str_2