Python的学习-----数字类型的转换\实例解析:凯撒密码
Python语言要提供type(x)函数对变量x进行类型判断,适用于任何数据类型
n=eval(input('请输入一个数字:'))
if type(n)==type(123):
print("输入的数字是整数。")
elif type(n) == type(11.3):
print("输入的数字是浮点数。")
else:
print("无法判断输入类型。")
数值运算操作符可以隐式地转换输出结果地数字类型,例如,两个整数采用运算符"/"的除法将可能输出浮点数结果。
此外,通过内置的数字类型转换函数可以显式地在数字类型之间进行转换。
实例解析:凯撒密码
凯撒密码是古罗马凯撒大帝用来对军事情报进行加密的算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母序列该字符后面第三个字符:
原文:A B C D E FG 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和字母A-Z按照密码算法进行转换
#CaesarEncode.py
ptxt= input("请输入明文文本:")
for p in ptxt:
if "a" <= p <= "z":
print(chr(ord("a")+(ord(p)-ord("a")+3)%26),end=' ')
elif "A" <= p <= "Z":
print(chr(ord("A")+(ord(p)-ord("A")+3)%26),end=' ')
else:
print(p,end=' ')
凯撒密码的解密算法程序首先接受用户输入的加密文本,然后对字母a-z和字母A-Z按照密码算法进行反向转换。
#CaesarEncode.py
etxt= input("请输入加密后文本:")
for p in etxt:
if "a" <= p <= "z":
print(chr(ord("a")+(ord(p)-ord("a")-3)%26),end=' ')
elif "A" <= p <= "Z":
print(chr(ord("A")+(ord(p)-ord("A")-3)%26),end=' ')
else:
print(p,end=' ')
如果加入汉字加密解密,只需加3减3即可:
#CaesarEncode.py
etxt= input("请输入加密后文本:")
for p in etxt:
if "a" <= p <= "z":
print(chr(ord("a")+(ord(p)-ord("a")-3)%26),end=' ')
elif "A" <= p <= "Z":
print(chr(ord("A")+(ord(p)-ord("A")-3)%26),end=' ')
elif 0x4E00 <= ord(p) <= 0x9FA5:
print(chr(ord(p)-3),end=" ")
else:
print(p,end=' ')
#CaesarDecode.py
etxt= input(“请输入加密后文本:”)
for p in etxt:
if “a” <= p <= “z”:
print(chr(ord(“a”)+(ord§-ord(“a”)-3)%26),end=’ ‘)
elif “A” <= p <= “Z”:
print(chr(ord(“A”)+(ord§-ord(“A”)-3)%26),end=’ ‘)
elif 0x4E00 <= ord§ <= 0x9FA5:
print(chr(ord§+3),end=" ")
else:
print(p,end=’ ')