题目:
加密方法:只用一个大写字母和原文进行异或运算生成密文。输入为两行,第一行表示有N个密文,第二行是N个密文。
输出:仅有大写字母组成的原文
样例输入:
30
17 6 9 8 3 0 1 6 7 4 5 10 11 8 9 14 15 12 13 18 19 16 17 22 23 20 21 26 27 24
样例输出:
SDKJABCDEFGHIJKLMNOPQRSTUVWXYZ
解题思路:
由于没有给出解密的大写字母,所以需要枚举,直到解密得到所有字母都为大写字母为止。
AC代码:
#include<stdio.h>
int main()
{
int c,t;
char x;
int a[100000];
int i,j;
char b[100000];
while(scanf("%d",&t)!=EOF)
{
for(i=0;i<t;i++)
scanf("%d",&a[i]);
for(i=0;i<26;i++)
{
c=i+‘A’;
for(j=0;j<t;j++)
{
b[j]=a[j]^c;
if(b[j]<‘A’||b[j]>‘Z’)
break;
}
if(j==t)
break;
}
for(i=0;i<t;i++)
printf("%c",b[i]);
printf("\n");
}
return 0;
}
破译密码
最新推荐文章于 2019-04-13 16:36:47 发布