完成下列凯撒加密算法

完成下面的凯撒加密算法,将明文输出为密文(移位次数由用户决定)。函数名: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