网站大量收购独家精品文档,联系QQ:2885784924

playfair加密解密供参习.docVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
playfair加密解密供参习

信息安全与加密技术课程报告 题 目:playfair加密 姓 名:彭小明 学 号:2008052117 班 级:信息081班 指导教师:姜云汉 完成日期:2011年10月12日 一.实验目的 撑握playfair加密的原理,以及加密思想。通边C、C++等编程语言实现playfair的加密与解密。 二.实验要求 2.1用C++等编程语言实现playfair的加密和解密 2.2明文(密文)能及密钥的大小写输入对密文(明文)的输出不受影响 2.3输出playfair的加密、解密矩阵 三.算法实现 3.1 程序设计 #includeiostream #includecstring using namespace std; //加密算法 void encrypt() { const int N=100; char letters[26]=ABCDEFGHIKLMNOPQRSTUVWXYZ;//用于填充矩阵 int flag[25]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};//字母是否已在矩阵中,与letters数组对应 char ch[5][5];//5X5矩阵 char ch1[N];//密钥 char ch2[N];//明文 char ch4;//无关字符 int len=a-A; cout输入密钥(a-z):; cinch1; int flg=1; while(flg==1) { for(int i=0;istrlen(ch1);i++)//把所输入的密钥转化为大写字母 { if(ch1[i]z||ch1[i]a) { cout请重新选择操作:endl; flg=0;break; } else ch1[i]=ch1[i]-len; } if(flg==1) { for(i=0;istrlen(ch1);i++)//把密钥中的J都变为I { if(ch1[i]==J)ch1[i]=I; } i=0;int j=0; //把密钥中的字母填入到矩阵中,并把该字母标记为已用 for(int k=0;kstrlen(ch1);k++) { for(int t=0;t25;t++) { if(ch1[k]==letters[t]flag[t]==0) { ch[i][j]=letters[t]; flag[t]=1; if(j4)j++; else {i++;j=0;} } } } for( k=0;k25;k++)//按字母表顺序把未用字母依次填入到矩阵中 { if(flag[k]==0) { ch[i][j]=letters[k]; flag[k]=1; if(j4)j++; else{i++;j=0;} } } cout密钥填充后的矩阵为: endl; for(i=0;i5;i++) for(j=0;j5;j++) { coutch[i][j]; cout ; if(j==4) coutendl; } coutendl; cout请输入明文(大写英文字符A-Z):; cinch2; cout输入一个无关字符:; cinch4; if(ch4=a) ch4=ch4-len; for(k=0;kstrlen(ch2);k++)//把所输入的明文转化为大写字母 { if(ch2[k]=a) ch2[k]=ch2[k]-len; } for(k=0;kstrlen(ch2);k++)//把明文中的J都变为I { if(ch2[k]==J) ch2[k]=I; } //为明文添加必要的无关字符以防止同一组的两个字符相同 for( k=0;kstrlen(ch2);k+=2) { if(ch2[k]==ch2[k+1]) { for(int t=strlen(ch2);tk;t--) ch2[t+1]=ch2[t]; ch2[k+1]=ch4; } } //若明文有奇数个字符,则添加一个无关字符以凑够偶数个

您可能关注的文档

文档评论(0)

dart004 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档