Python编程练习:编程实现恺撒密码

python基础

浏览数:81

2019-10-8

AD:资源代下载服务

问题描述:凯撒密码是古罗马凯撒大帝用来对军事情报进行加解密的算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母表序列中该字符后面的第三个字符,即,字母表的对应关系如下:

  原文:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

  密文:D E F G H I J K L M N O P Q R S T U V W X Y Z A B C

  对于原文字符P,其密文字符C满足如下条件:C=(P+3) mod 26

  上述是凯撒密码的加密方法,解密方法反之,即:P=(C-3) mod 26

  假设用户可能使用的输入仅包含小写字母a~z和空格,请编写一个程序,对输入字符串进行凯撒密码加密,直接输出结果,其中空格不用进行加密处理。使用input()获得输入。

示例:

源码:

Str = input()
for i in range(0, len(Str)):
    if Str[i] == ' ':
        print(' ', end="")
    elif Str[i] in ['x', 'y', 'z']:
        # print('{}'.format(chr(ord(Str[i]) - 23)), end="") #另一种写法
        print(chr(ord(Str[i])-23),end='')
    else:
        # print('{}'.format(chr(ord(Str[i]) + 3)), end="") #另一种写法
        print(chr(ord(Str[i])+3),end='')

 

作者:|旧市拾荒|