全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#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; else 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); Egcd(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=%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(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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 机械安全培训课件教学
- 护理新技术新疗法
- 护理技术与道德的重要性
- 车辆入口岗岗位制度模板
- 过渡孔混凝土梁施工技术方案模板
- 2026年剧本杀运营公司品牌定位与推广管理制度
- 生成式人工智能在跨校际教育科研合作中的数据挖掘与可视化研究教学研究课题报告
- 2026年自动驾驶汽车技术进展与政策分析报告
- 2025年智能音箱语音交互五年技术报告
- 国企纪委面试题目及答案
- 贵州省贵阳市(2024年-2025年小学五年级语文)部编版期末考试((上下)学期)试卷及答案
- 正规装卸合同范本
- 自动控制原理仿真实验课程智慧树知到答案2024年山东大学
- JBT 7946.2-2017 铸造铝合金金相 第2部分:铸造铝硅合金过烧
- 流程与TOC改善案例
- 【当代中国婚礼空间设计研究4200字(论文)】
- GB/T 20322-2023石油及天然气工业往复压缩机
- 提捞采油安全操作规程
- DB3211-T 1048-2022 婴幼儿日间照料托育机构服务规范
- YY/T 1846-2022内窥镜手术器械重复性使用腹部冲吸器
- GB/T 15390-2005工程用焊接结构弯板链、附件和链轮
评论
0/150
提交评论