替代密码及置换密码的c语言实现

替代密码及置换密码的c语言实现

ID:22397356

大小:182.50 KB

页数:13页

时间:2018-10-29

替代密码及置换密码的c语言实现_第1页
替代密码及置换密码的c语言实现_第2页
替代密码及置换密码的c语言实现_第3页
替代密码及置换密码的c语言实现_第4页
替代密码及置换密码的c语言实现_第5页
资源描述:

《替代密码及置换密码的c语言实现》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、WORD文档下载可编辑实验一一、实验名称:替代密码和置换密码的实现二、实验目的:通过编程实现替代密码算法和置换密码算法,加深对古典密码体系的了解,为以后深入学习密码学奠定基础。三、实验内容:A:替代密码1、实验原理:使用替代法进行加密,将明文中的字符用其他字符替代后形成密文。最早的替代密码是由JuliusCaesar发明的Caesar(恺撒)密码,又叫循环移位密码。它的加密过程可表示为:E(m)=(m+k)modn其中,m为明文字母在字母表中的位置数;n为字母表中的字母个数;k为密钥;E(m)为密文字母在字母表中对应的位置数。解密算法是:m=D(L

2、)=(L-k)mod26;2、算法设计:使用两个函数分别进行加密和解密的过程,在主程序中通过选择加密还是解密来调用不同函数进行替代密码的加密和解密过程实现;3、函数接口:加密:intencrypt(){printf("输入明文:");scanf("%s",a);for(i=0;a[i]!='';i++){b[i]=a[i]-64;}printf("输入一位密钥");scanf("%d",&k);printf("");for(i=0;b[i]!='';i++){m[i]=(b[i]+k)%26+64;}printf("%s",&m

3、);return0;}解密:intdecode(){printf("输入密文:");专业资料整理分享WORD文档下载可编辑scanf("%s",a);for(i=0;a[i]!='';i++){b[i]=a[i]-64;}printf("输入一位密钥");scanf("%d",&k);printf("");for(i=0;b[i]!='';i++){n[i]=(b[i]-k)%26+64;}printf("%s",n);return0;}4、程序流程图:专业资料整理分享WORD文档下载可编辑4、测试结果截图:加密:解密:B:1、

4、实验原理:专业资料整理分享WORD文档下载可编辑不改变明文字符,但是把字符在明文中的排列顺序改变,来实现明文信息的加密。置换密码也被称为换位密码。本次实验使用的是矩阵换位法,是将明文中的字母按照给定的顺序安排在一个矩阵中,然后又根据密钥提供的顺序重新组合矩阵中的字母,从而形成密文。解密过程是根据密钥的字母数作为列数,将密文按照列、行的顺序写出,再根据由密钥给出的矩阵置换产生新的矩阵恢复正常顺序,从而恢复明文。2、算法设计:通过选择加密或解密,使用置换矩阵顺序和恢复矩阵顺序的两个函数,分别在主函数中进行调用来实现置换密码的加密解密实现;3、函数接口:

5、加密:intjiami(){inti=0,j=0,key_len=0,text_len=0,row=0;charkey[LENGTH]={0};charnumber[LENGTH]={0};charptext[LENGTH*10]={0};charctext[LENGTH*10]={0};printf("输入明文:");scanf("%s",ptext);i=0;while(ptext[i]!=0){text_len++;i++;}printf("输入密钥:");scanf("%s",key);i=0;while(key[i]!=0){ke

6、y_len++;i++;}for(i=0;i

7、=0;i

8、H*10]={0};charnumber1[LENGTH]={0};printf("输入密文:");scanf("%s

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。