python编写凯撒密码!!!求大神帮助!!!

凯撒密码(Caesar 密码)是最早的代换密码,也是古典对称密码体制的典型代表,已经初
步体现出近代密码系统的雏形。其算法是:将每个字母用字母表中它之后的第k 个字母(称
作位移值)替代。例如:
明文:meet me after the toga party
密文:phhw ph diwhu wkh wrjd sduwb
(k=3)
现请你编写一个程序,请用户设定一个位移值,将用户输入的一段明文(由26 个字母及空
格组成的一个字符串),加密成一段密文,并将加密后的结果输出。
实验目的:
本实验帮助掌握字符串的基本操作,回顾理解ASCII 码的基本知识,帮助学生了解信息
加密的基本思想。
实验指导:
(1)用LIST 存放26 个小写字母
(2)编写一个函数,完成加密,考虑以下情况
·若输入的是小写字母,则计算它在字母表中按位移值算出的位置上的字母
·若输入的是大写字母,则则先将其转成小写字母,计算它在字母表中按位移值算出的位置
上的字母
·如果是空格,不需要转换
(3)调用所编写的函数,接收一段明文进行测试
最新回答
風的廻喑

2024-11-03 00:01:58

exec('moveLength = int(raw_input("Input raw_input amount, expect a int number"))\nprint "".join([dict(zip(list("abcdefghijklmnopqrstuvwxyz"), [list("abcdefghijklmnopqrstuvwxyz")[(i + moveLength) % 26] for i in range(26)]))[x] for x in list(raw_input("String to change:"))])')

楼主分没给够, 所以只能看到这样的代码喽……o((≧▽≦o) ......
陌生De自我ヾ忘却

2024-11-03 00:00:51


base = ord('a')
CHARLIST = [chr(base+i) for i in range(26)]


def charoff(ch, k):
    if ch == ' ':
        return ch
    pos = CHARLIST.index(ch.lower())
    return CHARLIST[(pos + k) % 26]


def caesar(orgstr, k):
    return ''.join([charoff(ch, k) for ch in orgstr])

print caesar('meet me after the toga party', 3)