【Educoder作业】※ 字符信息——凯撒加密
应读者要求,提前写了提前更出来。
整个作业我们主要就围绕
A
S
C
I
I
ASCII
ASCII码来做事,明确了计算机就是只存
01
01
01,连字符都是
01
01
01的。
T1 加密一个小写字母
只需要用 c h r chr chr和 o r d ord ord函数实现偏移即可。
########## Begin ##########
def enChar(x, key) :
y = ''
for i in x :
y = y + chr(ord(i) + key)
return y
########## End ##########
key = 2 #密钥(也就是偏移量)
for x in 'abcdefghijklmnopqrstuvwxyz': #对于所有小写字母
y = enChar(x, key) #求x对应的密文字符
print('%s -> %s' % (x, y))
T2 加密一个小写字母(续)
采用取模的方式,让加法固定在 a a a到 z z z里面即可。这个想法是比较实用的。
firstASCII = ord('a') #首个字符的ASCII码,请在enChar中使用
N = 26 #支持的字符总数,请在enChar中使用
########## Begin ##########
def enChar(x, key) :
y = ''
for i in x :
# i
y = y + chr((ord(x) + key - firstASCII) % 26 + firstASCII)
return y
########## End ##########
key = 2 #密钥(也就是偏移量)
for x in 'abcdefghijklmnopqrstuvwxyz': #对于所有小写字母
y = enChar(x, key) #求x对应的密文字符
print('%s -> %s' % (x, y))
T3 加密一段文本
就判断一下每一个字符的 A S C I I ASCII ASCII在不在我们需要的范围里即可。
firstASCII = ord('a') #首个字符的ASCII码
N = 26 #支持的字符总数
def enChar(x, key): #加密字符x,key为密钥
xid = ord(x)-firstASCII
yid = (xid+key) % N
y = chr(firstASCII+yid)
return y
########## Begin ##########
def Caesar(x, key) :
y = ''
for i in x :
dic = ord(i)
if firstASCII <= dic < firstASCII + N :
y = y + enChar(i, key)
else :
y = y + i
return y
########## End ##########
key = 2 #密钥
text = input() #明文
enText = Caesar(text, key) #加密
print('%s -> %s' % (text, enText))
T4 解密一段文本
所谓解密其实就是加法变减法,在取模定义里减法就是通过不断的加模数来维持答案始终在 0 0 0到 m o d − 1 mod-1 mod−1里。
########## Begin ##########
firstASCII = ord('a') #首个字符的ASCII码
N = 26 #支持的字符总数
def enChar(x, key):
xid = ord(x)-firstASCII
yid = (xid+key) % N
y = chr(firstASCII+yid)
return y
def Caesar(text, key):
result = ''
for x in text:
if 'a'<=x<='z':
x = enChar(x,key)
result = result + x
return result
key = 2 #密钥
text = input()
enText = Caesar(text, (26 - key) % 26)
print('%s -> %s' % (text, enText))
########## End ##########
T5 扩展到可视字符
就扩展一下咯,还是只需要改那个 i f if if、 f i r s t A S C I I firstASCII firstASCII和 N N N即可。
########## Begin ##########
firstASCII = 32 #首个字符的ASCII码
N = 95 #支持的字符总数
def enChar(x, key):
xid = ord(x)-firstASCII
yid = (xid+key) % N
y = chr(firstASCII+yid)
return y
def Caesar(text, key):
result = ''
for x in text:
#if 'a'<=x<='z': #若x是小写英文字母
if 32 <= ord(x) <= 126 :
x = enChar(x,key)
result = result + x
return result
key = 2 #密钥
text = input()
enText = Caesar(text, key)
print('%s -> %s' % (text, enText))
########## End ##########
T6 扩展到汉字
讲道理和第五题是没有任何区别的,就是把我们字符的范围和初始扩展一下即可。
########## Begin ##########
firstASCII = 0 #首个字符的编码
N = 65536 #支持的字符总数
def enChar(x, key):
xid = ord(x)-firstASCII
yid = (xid+key) % N
y = chr(firstASCII+yid)
return y
def Caesar(text, key):
result = ''
for x in text:
if firstASCII <= ord(x) < firstASCII + N : #若x是可视字符
x = enChar(x,key)
result = result + x
return result
key = 2 #密钥
text = input()
enText = Caesar(text, key)
print('%s -> %s' % (text, enText))
########## End ##########