771 密钥解密【字符串处理】

密钥解密

时间限制: 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;
}


  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值