下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#include #include #include #include #include char s100,*c;int n,e,d,i,C,j,k=0,len;int str100,b30;unsigned gcd(unsigned a, unsigned b )if(a%b=0)return b; else return gcd(b,a%b);void Egcd(int a, int b,int &x, int &y) /ax-by=1 if(b=0|a=0) x=1; y=0; return ; if(ab) Egcd(a,b%a,x,y); x=(int)(b*y+1)/a; els
2、e Egcd(a%b,b,x,y); y=(int)(a*x-1)/b; void RSA()int p,q,N,Y; printf(请输入素数p和q:); scanf(%d %d,&p,&q); n=p*q; N=(p-1)*(q-1); /printf(n=%d N=%dn,n,N); srand( (unsigned)time( NULL ) ); /初始化随机数 while(1) /产生随机整数e,e与N互质 e=rand()%N;/ printf(e=%dn,e); if(e=0) continue; if(gcd(N,e)=1) break; /printf(e=%dn,e); E
3、gcd(e,N,d,Y); / printf(d=%d Y=%dn,d,Y); printf(公钥PU=e=%d,n=%dn,e,n); printf(私钥PR=d=%d,n=%dn,d,n);void encrypt() /加密函数len=strlen(s);/hgprintf(len=%dn,len); for(i=0;ilen;i+) /去掉s100中的空格 if(si122) bk=i; k+; for(j=i;jlen-1;j+) sj=sj+1; len-; slen=0; /结束符printf(密文是:); for(i=0;ilen;i+) C=1; /printf(shiji=
4、%dn,si-97);for(int j=0;je;j+)C=(C*(si-97)%n;/printf(C=%ldn,C); stri=C;printf(%d ,stri);printf(n); void decrypt() /解密函数c=(char*)malloc(len*sizeof(int); for(i=0;ilen;i+) /实现解密 C=1;for(int j=0;jd;j+)C=(C*(stri)%n;/printf(C=%ldn,C);/printf(C=%dn,C); ci=C+97; ci = 0; / puts(c);for(int z=0;zk;z+) /加空格 for
5、(i=0; ii;j-) cj=cj-1; ci= ; len+; bz+1=bz+1+(z+1); break; clen = 0; printf(明文:); puts(c);int function()/系统功能选择页面 int choice; printf(=n); printf( 欢迎进入RSA算法 n); printf( 1-加密 n); printf( 2-解密 n); printf( 3-退出 n); printf(=n); printf(请输入要选择的功能号:); scanf(%d,&choice); return choice;int main() int function(); int fc; printf(请输入初始明文(小写):); gets(s); / puts(s); RSA(); /提供私钥和公钥 while(1) fc=function(); if(fc=1) /加密 encrypt(); el
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 第3课 分支结构程序设计教学设计初中信息技术滇人版2016八年级下册-滇人版2016
- 江西省九江市实验中学高二数学 第二章 第十一课时《离散型随机变量的均值》教案 北师大版选修2-3
- 2026济南文旅发展集团有限公司校园招聘20人备考题库含答案详解(完整版)
- 2026安徽铜陵市普济种子有限公司招聘派遣制人员1人备考题库及答案详解【有一套】
- 2026年继续教育基层常见病的诊疗与管理题库及答案解析
- 人教版PEP(2024)Unit4 Plants around usPart B教案及反思
- 2026内蒙古鄂尔多斯东胜区第一小学三部教师招聘1人备考题库附答案详解(完整版)
- 2026中葡经贸中心招聘6人备考题库及参考答案详解一套
- 中国中煤能源集团有限公司2026届高校毕业生春季招聘备考题库及答案详解(考点梳理)
- 2026广西柳州融安县长安镇卫生院乡村医生招聘2人备考题库及答案详解(名师系列)
- DB44∕T 2784-2025 居家老年人整合照护管理规范
- 湖北省十一校2026届高三第二次联考生物生物试卷(含答案)
- 2026年遥感技术助力生物多样性监测
- 园区卫生管理责任制度
- 幕墙施工噪音控制方案
- 弹载大容量多参数测试仪的关键技术与研制实践
- 2026年银行系统运维岗招聘笔试模拟题含答案
- 2026年河南省事业单位工勤技能考试考试题库及参考答案
- 保安门卫勤务培训课件
- 仓储库存周转率优化与呆滞物料清理报告
- 2025年复旦大学管理职员统一公开招聘备考题库含答案详解
评论
0/150
提交评论