admin管理员组文章数量:1794759
python自学做题记录之凯撒密码
【问题描述】 凯撒密码是古罗马凯撒大帝用来保护重要军情的加密系统。这套密码系统在现在看来很低级,但是在古罗马时期还是发挥了重要作用的。 凯撒密码的根本思想是按照字母表排列顺序将明文中每个字母变换成其后第n个字母。这里,n(n=1~25)被称作秘钥。 请编写程序,针对不同的输入字符串和移动位数,输出经过凯撒加密之后的字符串。
【输入形式】 第一个输入参数是移动的位数n,中间间隔一个空格之后,第二个输入参数是待加密的原文字符串 【输出形式】 加密后的密文字符串。注意,只加密字母,且不改变字母大小写。待加密的字符串可能存在比如"hello world"的形式,若与第一个参数一起以input的方式输入,在调用split()的时候要注意,会将待加密字符串也一并分割了。split()方法有参数指定分割多少项,建议采用,请上网搜索说明文档。 【样例输入】 5 NUDT 【样例输出】 SZIY 【样例说明】 输入参数中第一个参数’5’表示移动位数n=5,然后将第二个输入参数中每个字母都向后移动5位,得到输出字符串。
这里直接使用ord 和chr 函数就可以,但是要注意如果移动后的字母大于z或者Z时需要ASCII值减去26
key,zifu=input().split(' ',1) outcome="" for i in zifu: if i.isalpha(): i=chr(ord(i)+int(key)) if 'a'>i>'Z': i = chr(ord(i) - 26) elif i>'z': i = chr(ord(i) - 26) outcome += i print(outcome)版权声明:本文标题:python自学做题记录之凯撒密码 内容由林淑君副主任自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.xiehuijuan.com/baike/1686481810a72421.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论