欢迎来到天天文库
浏览记录
ID:13713436
大小:145.00 KB
页数:17页
时间:2018-07-24
《现代密码学实验报告(题目代码)丁朋》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、实验报告实验课程名称现代密码学学院理学院年级08专业班03学生姓名丁朋学号25开课时间2010至2011学年第二学期总成绩教师签名实验项目名称实验一、古典密码(认识密码学)成绩一、实验目的通过实现简单的古典密码算法,理解密码学的相关概念如明文(plaintext)、密文(ciphertext)、加密密钥(encryptionkey)、解密密钥(decryptionkey)、加密算法(encryptionalgorithm)、解密算法(decryptionalgorithm)等。二、实验内容1)用CC++语言实现仿射变换(Affine)加/解密算法;2)用CC++语言实现统计26
2、个英文字母出现的频率的程序;3)利用仿射变换加/解密程序对一段较长的英文文章进行加密,再利用统计软件对明文和密文中字母出现的频率进行统计并作对比,观察有什么规律。放射变换:加密:解密:其中a,b为密钥,,且gcd(a,26)=1实验要求:加/解密程序对任意满足条件的a、b都能够处理。三、实验步骤(1)统计26个英文字母出现的频率的程序#include#include#includeusingnamespacestd;voidmain(){ifstreamin("a.txt");vectors;vectorn(
3、26,0);for(inti=0;i<26;++i)s.push_back(97+i);for(charx;in>>x;)for(inti=0;i<26;++i)if(int(x)==s[i]){n[i]++;}floatsum=0.0;for(intj=0;j<26;++j)sum+=n[j];cout<<"统计结果如下:"<4、的英文文章进行加密#include#include#includeusingnamespacestd;//////////判断两个数是不是互素(辗转相除)////////boolgcd(inta){intf=26,g,r;g=a;do{r=f%g;f=g;g=r;}while(r);if(f==1)return1;elsereturn0;}//////////////////求逆//////intinv(inta){intx,i;for(i=1;i<=30;++i)if((26*i+1)%a==0){x=(26*i+1)/a;b5、reak;}returnx;}//////////////////////////////////////////////////////////voidmain(){cout<<"请你选择操作密码的方式:"<>z;if(z==06、7、z==1){//////////////////////////////////////////cout<<"请输入密钥a和b:"<>a>>b;if((a<18、9、a>25)10、11、(b<012、13、b>25))cout<<"a,b的输入14、范围有错!"<s;for(charx;in>>x;)s.push_back(int(x));for(inti=0;i15、/解密算法{ifstreamin("b.txt");ofstreamout("a.txt");vectors;for(charx;in>>x;)s.push_back(int(x));for(inti=0;i
4、的英文文章进行加密#include#include#includeusingnamespacestd;//////////判断两个数是不是互素(辗转相除)////////boolgcd(inta){intf=26,g,r;g=a;do{r=f%g;f=g;g=r;}while(r);if(f==1)return1;elsereturn0;}//////////////////求逆//////intinv(inta){intx,i;for(i=1;i<=30;++i)if((26*i+1)%a==0){x=(26*i+1)/a;b
5、reak;}returnx;}//////////////////////////////////////////////////////////voidmain(){cout<<"请你选择操作密码的方式:"<>z;if(z==0
6、
7、z==1){//////////////////////////////////////////cout<<"请输入密钥a和b:"<>a>>b;if((a<1
8、
9、a>25)
10、
11、(b<0
12、
13、b>25))cout<<"a,b的输入
14、范围有错!"<s;for(charx;in>>x;)s.push_back(int(x));for(inti=0;i15、/解密算法{ifstreamin("b.txt");ofstreamout("a.txt");vectors;for(charx;in>>x;)s.push_back(int(x));for(inti=0;i
15、/解密算法{ifstreamin("b.txt");ofstreamout("a.txt");vectors;for(charx;in>>x;)s.push_back(int(x));for(inti=0;i
此文档下载收益归作者所有