ImageVerifierCode 换一换
格式:DOC , 页数:8 ,大小:50.50KB ,
资源ID:3073219      下载积分:15 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-3073219.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(凯撒密码--C语言实现.doc)为本站会员(11****ws)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

凯撒密码--C语言实现.doc

1、凯撒密码是一种非常古老的加密方法,相传当年凯撒大地行军打仗时为了保证自己的命令不被敌军知道,就使用这种特殊的方法进行通信,以确保信息传递的安全。他的原理很简单,说到底就是字母于字母之间的替换。下面让我们看一个简单的例子:“baidu”用凯撒密码法加密后字符串变为“edlgx” ,它的原理是什么呢?把“baidu”中的每一个字母按字母表顺序向后移 3 位,所得的结果就是刚才我们所看到的密文。/*凯撒密码实现要求,将明文字母变成它后面第三个字母,后面的循环到前面!公式为 f(a)=(f(a)+3)%26*/#include int main()char P100;/*定义明文长度 */char C

2、100;/*定义密文长度 */int K=3,i;printf(“Please input Plaintext:n“); /*输入明文*/gets(P); /* 接受明文*/for(i=0;Pi!=0;i+) /*逐个判断字母的大小*/if(Pi=aprintf(“n=“);printf(“n1.Encrypt the file“);printf(“n2.Decrypt the file“);printf(“n3.Quitn“);printf(“=n“);printf(“Please select a item:“);return;char encrypt(char ch,int n)/*加密

3、函数,把字符向右循环移位 n*/while(ch=A*(pwd+i)!=0;i+)if(*(pwd+i)=aelse *(pwd+i)=z-(key%26-(*(pwd+i)-a)-1;else if(*(pwd+i)=Aelse *(pwd+i)=Z-(key%26-(*(pwd+i)-A)-1;return pwd;void main()char *pwd;int key;pwd=(char*)malloc(sizeof(char);printf(“Input your password:“);gets(pwd);printf(“Input a key:“);scanf(“%d“,prin

4、tf(“The Ciphertext is:“);printf(“%sn“,Encrypt(pwd,key);-/*替换法:*/#include #include #include void table(char *keyword) /*筛选密钥(去重复去空格)*/int i,j,k;for(i=0;*(keyword+i)!=0;i+)for(j=i;*(keyword+j)!=0;j+)if(i!=j)if(*(keyword+i)=*(keyword+j)|*(keyword+j)= )for(k=j;*(keyword+k)!=0;k+)*(keyword+k)=*(keyword+k

5、+1);j-;void newTab(char *keyword) /*生成密钥表*/char ch;int i;int t;for(t=0;*(keyword+t)!=0;t+);for(ch=a;ch=z;ch+)for(i=0;*(keyword+i)!=ch;i+)if(*(keyword+i)=0)*(keyword+t)=ch;t+;break;*(keyword+t)=0;char *Ciphertext(char *keyword,char *Plaintext) /*按密码表加密*/char ch;int i,j;for(i=0;*(Plaintext+i)!=0;i+)fo

6、r(ch=a,j=0;ch=z;ch+,j+)if(*(Plaintext+i)=ch)*(Plaintext+i)=*(keyword+j);break;return Plaintext;char *Decrypt(char *keyword,char *Plaintext) /*解密*/char ch;int i,j;for(i=0;*(Plaintext+i)!=0;i+)for(ch=a,j=0;*(keyword+j)!=0;ch+,j+)if(*(Plaintext+i)=*(keyword+j)*(Plaintext+i)=ch;break;return Plaintext;vo

7、id main()char *keyword,*Plaintext,*tmp=NULL;keyword=(char*)malloc(sizeof(char);Plaintext=(char*)malloc(sizeof(char);printf(“Input key word:“); /*输入欲用密钥*/gets(keyword);printf(“Input Plaintext:“); /*输入要转换的明文*/gets(Plaintext);table(keyword); /*去空格去重复*/newTab(keyword); /*生成密码表 */tmp=Ciphertext(keyword,Plaintext); /*对应着密码表生成密文*/puts(tmp); /*输出密文*/puts(Decrypt(keyword,tmp); /*解密输出*/

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。