#include<iostream.h>
#include <stdlib.h>
#include<math.h>
#include<String.h>
int r; //公开模数
int sk; //私人密钥
int pk; //公开密钥
int Euler;//欧拉函数
int check(int x)
{
for(int i=2;i<=x-1;i++)
{
if(x%i==0) break;
}
if(i==x) return 1;
else return 0;
}
void produceSS()
{
int p,q;
int flag=0;
int n=0;
cout<<"输入值不要太大,防止溢出!"<<endl;
while(flag==0)
{
if(n>0) cout<<"p应为素数,请重新输入!"<<endl;
cout<<"请输入素数p:";
cin>>p;
flag=check(p);
n++;
}
flag=0;
n=0;
while(flag==0)
{
if(n>0) cout<<"q应为素数,请重新输入!"<<endl;
cout<<"请输入素数q:";
cin>>q;
flag=check(q);
n++;
}
r=p*q;
cout<<"公开模数:r="<<r<<endl;
Euler=(p-1)*(q-1);
cout<<"欧拉函数:Euler="<<Euler<<endl;
}
int gcd(int x,int y)
{
int a=x;
int b=y;
int z;
b++;
do
{
b--;
x=a;
y=b;
while(x%y!=0)
{
z=x%y;
x=y;
y=z;
}
}while(z>1);
return b;
}
int trAsc(int s,int a[]) //转为二进制数
{
int x=s;
int n=0;
while(x!=0)
{
a[n]=x%2;
x=x/2;
n++;
}
return n;
}
int pfc(int x,int key) //平方乘
{
int a[13];
int m=trAsc(key,a); //二进制位数
int c=1;
for(int i=m-1;i>=0;i--)
{
c=c*c%r;
if(a[i]==1) c=c*x%r;
}
return c;
}
int producePk()
{
int a1=sk;
int r1=r;
int q1, p1;
int b1=0;
int b2=1;
int b3;
do{
cout<<a1<<endl;
p1=r1/a1;
q1=r1%a1;
b3=b1-b2*p1;
b1=b2;
b2=b3;
r1=a1;
a1=q1;
}while(a1!=1);
return abs(b2);
}
void produceKey()
{
int k;
int n=0;
int flag=0;
int b1=0;
int b2=1;
int a,c,q,p;
cout<<"初始密钥应小于欧拉函数:"<<r<<endl;
cout<<"请输入初始密钥:";
cin>>sk;
sk++;
do
{
sk--;
sk=abs(sk);
sk=gcd(Euler,sk);
b1=0;
b2=1;
a=sk;
c=Euler;
do
{
q=c/a;
p=c%a;
pk=b1-b2*q;
c=a;
a=p;
b1=b2;
b2=pk;
}while (p!=1);
pk=abs(pk);
a=pfc(8,sk);
c=pfc(a,pk);
} while(c!=8); //加密、解密正确判断
cout<<"私人密钥:sk="<<sk<<endl;
cout<<"公开密钥:pk="<<pk<<endl;
}
void Encryption() //加密
{
int Express;
int flag=1;
while(flag)
{
cout<<"明文编码应小于公开模数r:"<<r<<endl;
cout<<"请输入要加密的明文编码(十进制数):";
cin>>Express;
if(Express>r)
cout<<"明文编码应大于公开模数,请重新输入!"<<endl;
else flag=0;
}
cout<<"sk="<<sk<<endl;
cout<<"原编码为:"<<Express;
Express=pfc(Express,sk);
cout<<"密文为:"<<Express<<endl;
}
void Decrypt()//减密
{
int Express;
int flag=1;
while(flag)
{
cout<<"密文编码应小于公开模数r:"<<r<<endl;
cout<<"请输入要加密的密文编码(十进制数):";
cin>>Express;
if(Express>r)
cout<<"密文编码应大于公开模数,请重新输入!"<<endl;
else flag=0;
}
cout<<"pk="<<pk<<endl;
cout<<"原编码为:"<<Express;
Express=pfc(Express,pk);
cout<<"明文为:"<<Express<<endl;
}
void main()
{
int flag=1;
int step;
int n;
while(flag)
{
cout<<"1.产生素数"<<endl;
cout<<"2.产生密钥"<<endl;
cout<<"3.加密"<<endl;
cout<<"4.解密"<<endl;
cout<<"5.退出"<<endl;
cout<<"请输入您的操作(1,2,3,4或5):";
cin>>step;
switch(step)
{
case 1:produceSS();
break;
case 2:produceKey();
break;
case 3:Encryption();
break;
case 4:Decrypt();
break;
case 5:exit(0);
break;
}
}
}
![avatar](https://profile-avatar.csdnimg.cn/c23ee78d05aa4a42a4e1de0579803699_virtualpc.jpg!1)
afunti
- 粉丝: 25
- 资源: 41
最新资源
- 新能源汽车动力经济性能EDQ目标分解SSTS详解:提升行驶效率与节能减排的实用策略,新能源汽车动力经济性能EDQ目标分解SSTS详解:打造高效动力,提升经济性,新能源汽车动力经济性能EDQ目标分解SS
- (源码)基于Vue框架的电商后台管理系统.zip
- **COMSOL与MATLAB代码实现随机分布球圆模型:多孔介质模拟及三维二维打包程序**,**COMSOL与MATLAB代码实现随机分布球圆模型:多孔介质模拟及三维二维打包程序**,COMSOL w
- (源码)基于C++编程语言的Hydra操作系统.zip
- 基于Comsol的压裂井降压开采模拟算例:熟悉方法,研究油藏与地热开采的数值模拟,基于Comsol的压裂井降压开采数值模拟算例:解析压裂开采模拟方法及地热与油藏开采应用,comsol压裂井降压开采算例
- (源码)基于Python的微信智能机器人系统.zip
- COMSOL模拟流固耦合井筒应力分布:径向荷载作用下的多物理场分析建模说明书,COMSOL模拟流固耦合井筒应力分布:径向荷载作用下的多物理场分析建模说明书,COMSOL模拟流固耦合井筒周围应力分布
- (源码)基于实时操作系统(RTOS)的嵌入式多任务系统.zip
- 二维钻孔封孔技术效果模拟案例:从实践到理论,探索最佳封孔策略,二维钻孔封孔效果模拟案例分析:多场景应用与实验验证,二维钻孔封孔效果模拟案例 ,二维钻孔; 封孔效果; 模拟案例; 效果评估; 钻孔参数
- (源码)基于C++的几何图形计算程序.zip
- (源码)基于Java的UML解析器.zip
- COMSOL模拟:二维轴对称模型下的水热力三场耦合问题解析,COMSOL冻土中水热应力三场耦合模型的瞬态与稳态分析:详解与案例文档,comsol本案例建立成二维轴对称模型,物理场采用两个PDE模块,分
- (源码)基于pyecharts的数据流拓扑仿真器.zip
- COMSOL水驱油案例:两相流技术应用于石油开发的基础分析,一注四采及注水井采油井开发井网解析 ,COMSOL模拟案例:水驱油两相流在石油开发中的应用与效益,注一采四之下的油田基础实践及高效开发井网探
- (源码)基于Arduino的Eurorack合成器语音模块.zip
- 基于COMSOL的裂隙动水注浆扩散模拟:研究两种速凝浆液特性对扩散过程的影响,COMSOL裂隙动水注浆扩散模拟:研究水泥-水玻璃与高聚物改性水泥浆液扩散规律及黏度时变特性影响分析,COMSOL裂隙动水
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback](https://img-home.csdnimg.cn/images/20220527035711.png)
![feedback-tip](https://img-home.csdnimg.cn/images/20220527035111.png)