include iostream;
using namespace std;
#define N 6 //定义N的大小
#define M 5 //定义M的大小,N=M
void main()
{
char P[N]={0};
char K[M]={0};
char C[M]={0};//因为要用Ki加密,所以C[]只能有M个大
int i,j;//定义循环变量
cout "请输入明文数组,你可以输入"N"个字符长度"endl;
for (i=0;iN;i++)//为P[N]赋值
{
cout " P"i"=";
cin P[i];
}
cout "请输入密钥数组,你可以输入"M"个字符长度"endl;
for (j=0;jM;j++)//为K[M]赋值
{
cout "K"j"=";
cin K[j];
}
for (i=0;iM;i++)//加密!因为K[j]个数有限,只能用M做为循环次数
{
j=i%(M+1);
C[i]=P[i]+K[j];
cout P[i]endl;
cout K[j]endl;
cout C[i]endl;
if (0C[i])//7F=127
{
//C[cnt]=P[cnt]+K[i%(j+1)];//Ci=Pi+Kj(j=i mod(m+1)) (当Ci=7FH)
C[i]=C[i]+128;
cout C[i]endl;
}
else
{
//C[cnt]=P[cnt]+K[i%(j+1)]-128;//Ci=Pi+Kj-80H(j=i mod(m+1)) (当Ci7FH)
C[i]=C[i];
cout C[i]endl;
}
}
coutendlendl"输出加密后的密文C[i]如下:"endl;
for (i=0;i=40;i++)
cout "#";
cout endl;
for (i=0;iM;i++)//输出加密后的C[i]
{
cout C[i]endl;
}
for (i=0;i=40;i++)
cout "#";
cout endl;
for (i=0;iM;i++)//解密!因为K[j]个数有限,只能用M做为循环次数
{
j=i%(M+1);
if (C[i]=K[j])
{
P[i]=C[i]-K[j]+128;//Pi=Ci-Kj (j=i mod(m+1)) (当Ci=Kj)
}
else
{
P[i]=C[i]-K[j];//80H=128,Pi=Ci-Kj+80H(j=i mod(m+1))(当CiKj)
}
}
coutendlendl"输出解密后的明文P[i]如下:"endl;
for (i=0;i=36;i++)
cout "#";
cout endl;
for (i=0;iN;i++)//输出解密后的P[i]
{
cout P[i]endl;
}
for (i=0;i=36;i++)
cout "#";
cout endlendl;
include iostream;
using namespace std;
#define N 6 //定义N的大小
#define M 5 //定义M的大小,N=M
void main()
{
char P[N]={0};
char K[M]={0};
char C[M]={0};//因为要用Ki加密,所以C[]只能有M个大
int i,j;//定义循环变量
cout "请输入明文数组,你可以输入"N"个字符长度"endl;
for (i=0;iN;i++)//为P[N]赋值
{
cout " P"i"=";
cin P[i];
}
cout "请输入密钥数组,你可以输入"M"个字符长度"endl;
for (j=0;jM;j++)//为K[M]赋值
{
cout "K"j"=";
cin K[j];
}
for (i=0;iM;i++)//加密!因为K[j]个数有限,只能用M做为循环次数
{
j=i%(M+1);
C[i]=P[i]+K[j];
cout P[i]endl;
cout K[j]endl;
cout C[i]endl;
if (0C[i])//7F=127
{
//C[cnt]=P[cnt]+K[i%(j+1)];//Ci=Pi+Kj(j=i mod(m+1)) (当Ci=7FH)
C[i]=C[i]+128;
cout C[i]endl;
}
else
{
//C[cnt]=P[cnt]+K[i%(j+1)]-128;//Ci=Pi+Kj-80H(j=i mod(m+1)) (当Ci7FH)
C[i]=C[i];
cout C[i]endl;
}
}
coutendlendl"输出加密后的密文C[i]如下:"endl;
for (i=0;i=40;i++)
cout "#";
cout endl;
for (i=0;iM;i++)//输出加密后的C[i]
{
cout C[i]endl;
}
for (i=0;i=40;i++)
cout "#";
cout endl;
for (i=0;iM;i++)//解密!因为K[j]个数有限,只能用M做为循环次数
{
j=i%(M+1);
if (C[i]=K[j])
{
P[i]=C[i]-K[j]+128;//Pi=Ci-Kj (j=i mod(m+1)) (当Ci=Kj)
}
else
{
P[i]=C[i]-K[j];//80H=128,Pi=Ci-Kj+80H(j=i mod(m+1))(当CiKj)
}
}
coutendlendl"输出解密后的明文P[i]如下:"endl;
for (i=0;i=36;i++)
cout "#";
cout endl;
for (i=0;iN;i++)//输出解密后的P[i]
{
cout P[i]endl;
}
for (i=0;i=36;i++)
cout "#";
cout endlendl;
∵对应关系为z-m,n-a,g-t,u-h,f-s
∴密文znguf转换为明文,应该是maths.
将明文转换成密文的过程叫加密,将密文经过逆变换恢复成明文的过程叫解密。
一般是指密码在经过人工加密后,所传输的直接信息被加密,称为“密文”。
而接受方通过共同的密码破译方法将其破译解读为直接的文字或可直接理解的信息,称为“明文”。
是正整数,1≤x ≤26, 被3整除)是正整数,1≤x ≤26, 被3除余1)是正整数,1≤ x≤26, 被3除余2) 这几句是什么意思,楼主你好歹把题目写清楚嘛~
调了半天,楼主真是太粗心了!middle1[]应该这样声明:
char middle1[]={'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
最后输出start的时候要注意控制长度,改个for循环就好了!
#includestdio.h
#includestring.h
int main(void)
{
int i,j,length,n;
char temp;
char middle2[27];
char start[201],finish[201];
char middle1[]={'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'};
gets(middle2);
gets(finish);
scanf("%d",n);
length=strlen(finish);
for(i=0;i25;i++)
{
for(j=i+1;j26;j++)
{
if(middle2[i]middle2[j])
{
temp=middle2[i];
middle2[i]=middle2[j];
middle2[j]=temp;
temp=middle1[i];
middle1[i]=middle1[j];
middle1[j]=temp;
}
}
}
for(i=1;i=n;i++)
{
for(j=0;jlength;j++)
{
if(finish[j]==' ')
{
start[j]=' ';
}
else
{
start[j]=middle1[finish[j]-'A'];
}
}
}
for( i = 0;i length;++i)
printf("%c",start[i]);
printf("\n");
return 0;
}
/*
ABCDEFGHIJKLMNOPQRSTUVWXYZ
*/