PTA 凯撒密码 python解决

(凯撒密码)是一个简单的替换加密技术,它简单地将明文字符串中的全部字母在字母表上偏移n项。当n大于0时,表示向后偏移,小于0则表示向前偏移。当n为2时,字母A变C,c变e,y变a, Z变B;当n为-2时,字母A变Y,c变a,y变w,Z变X。请编写程序,依次读入明文字符串及整数偏移量n,然后输出加密后的密文字符串。提示:C语言可用gets()函数,C++语言可用getline()函数读入整行字符串。

样例">样例">样例">样例">输入样例:

No One Can Stop Us
2

输出样例:

Encrypted message:Pq Qpg Ecp Uvqr Wu

考虑一下的情况:①n>26或n<-26②上越界,如Z偏移3③下越界,如a偏移-2.

完整代码:

a=input()
n=int(input())
N=abs(n)%26
print("Encrypted message:",end="")
for i in range(len(a)):
    if 65<=ord(a[i])<=90:
        if n>=0 and ord(a[i])+N>90:
            print(chr(ord(a[i])+N-26),end="")
        elif n>=0 and ord(a[i])+N<=90:
            print(chr(ord(a[i])+N),end="")
        elif n<0 and ord(a[i])-N<65:
            print(chr(ord(a[i])-N+26),end="")
        elif n<0 and ord(a[i])-N>=65:
            print(chr(ord(a[i])-N),end="")
    elif 97<=ord(a[i])<=122:
        if n>=0 and ord(a[i])+N>122:
            print(chr(ord(a[i])+N-26),end="")
        elif n>=0 and ord(a[i])+N<=122:
            print(chr(ord(a[i])+N),end="")
        elif n<0 and ord(a[i])-N<97:
            print(chr(ord(a[i])-N+26),end="")
        elif n<0 and ord(a[i])-N>=97:
            print(chr(ord(a[i])-N),end="")
    else:
        print(a[i],end="")

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值