2021-10-22

2021-10-22,第1张

2021-10-22

一、实验目的
   编制基本的文本加、解密程序 
二、实验内容
   凯撒加解密、维吉尼亚表加解密、DES加解密
三、实验要求
   使用任意高级语言(Python)做出给文本文件加、解
密的软件. 
四、实验步骤: 
   参考有关内容,编制程序,界面要求如下

参考:凯撒加解密 

def KaiSaEncrypt(ch, k):
    if (not isinstance(ch, str)) or len(ch)!=1:
        print('The first parameter must be a character')
        return
    if (not isinstance(k, int)) or (not 1<=k<=25):
        print('The second parameter must be an integer between 1 and 25')
        return
    if 'a'<=ch<=chr(ord('z')-k): #把英文字母变换为后面第k个字母
        return chr(ord(ch)+k)
    elif chr(ord('z')-k)         return chr((ord(ch)-ord('a')+k)%26+ord('a'))
    elif 'A'<=ch<=chr(ord('Z')-k):
        return chr(ord(ch)+k)
    elif chr(ord('Z')-k)         return chr((ord(ch)-ord('A')+k)%26+ord('A'))
    else:
        return ch
def encrypt(plain, k):
        return ''.join([KaiSaEncrypt(ch, k) for ch in plain])
def KaiSaDecrypt(ch, k):
    if (not isinstance(ch, str)) or len(ch)!=1:
        print('The first parameter must be a character')
        return
    if (not isinstance(k, int)) or (not 1<=k<=25):
        print('The second parameter must be an integer between 1 and 25')
        return
    if chr(ord('a')+k)<=ch<='z': #然后把每个字母变换为前面第k个字母
        return chr(ord(ch)-k)
    elif 'a'<=ch         return chr((ord(ch)-k+26))
    elif chr(ord('A')+k)<=ch<='Z':
        return chr(ord(ch)-k)
    elif 'A'<=ch         return chr((ord(ch)-k+26))
    else:
        return ch
def decrypt(plain, k):
        return ''.join([KaiSaDecrypt(ch, k) for ch in plain])
plainText = 'Explicit is better than implicit.'
cipherText = encrypt(plainText, 5)
print(plainText)
print(cipherText)
print(decrypt(cipherText,5))

程序运行结果为:
Explicit is better than implicit.
Jcuqnhny nx gjyyjw ymfs nruqnhny.
Explicit is better than implicit.

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4676163.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-06
下一篇 2022-11-06

发表评论

登录后才能评论

评论列表(0条)

保存