密钥解密
时间限制:
1000 ms | 内存限制:
65535 KB
难度:
1
-
描述
-
密钥加密是将密钥数字串值循环加到明文(需要加密的文字串)上,使得明文变形而不可阅读,变形后的文字串称为密文。例如,密钥为4972863,明文为“the result of 3 and 2 is not 8”,则循环加密的过程及结果为:
即密文为:
xql"zkvyu "wl#7)hpl&5$rz"vuw$A
这里的密钥加密是循环加密,并且在ASCII码值32(’ ’)到122(’z’)之间做模运算,超过了122的值便依次回跳到32,33,...等值。例如,’t’+7=116+7=123=122+1,其值超过122一个位置,因此回跳到值32。显然,密文也全部是由可见字符所组成。-
输入
- 输入数据中含有若干组数据,每组数据由密钥和明文组成,密钥和明文均单独占一行。每组数据之间没有空行。 输出
- 对于每组数据,对应输出一行密文。 样例输入
-
4972863 the result of 3 and 2 is not 8 123 Hello World
样例输出
-
xql"zkvyu "wl#7)hpl&5$rz"vuw$A Igomq#Xqumf
这个题不难,但是错了很多遍,找到最后才发现,是char 太小了,处理的时候可能溢出成为负值,然后一直wa!!!
另外这个题没给出范围,目测是一万...数组开到一万就行.....
第一次见到这样的情况,也是长记性了..........
#include<stdio.h>
#include<string.h>
int main()
{
char x[10005],num[10005];
while(~scanf("%s ",num))
{
gets(x);
int len=strlen(num);
for(int i=0;x[i]!=0;++i)
{
int tp;
tp=x[i]+num[i%len]-'0';//这里是重点!,用个临时变量
if(tp>122)
{
tp=tp%122+31;
}
x[i]=tp;
}
printf("%s\n",x);
}
return 0;
}