小鑫在高中的时候喜欢上了一个十分漂亮的女孩。那个女孩也很喜欢他,就答应成为他的女朋友。
但是大家都知道高中的生活是忙碌的,除了上课就是上课,有时候可能连课间时间都被老师占用。于是小鑫想出了在上课给女朋友传纸条的方法来表达自己的爱慕。
又但是她与小鑫之间的距离太远,中间必须通过同学来传递纸条。可他们并不想让同学们知道写的什么就想到加密纸条这种方法。方法如下:
他们每天都会约定加密常数n,举个例子,当n=1时,今天写的每一句话中所用的字母都会向后+1,比如:i love you就成了j mpwf zpv ,当然了当是z的时候,+1就等于a。
请你帮他女朋友解密他写的纸条么?
#include<stdio.h>
#include<string.h>
#include<math.h>
#include<stdlib.h>
int main()
{
int n;
while(scanf("%d",&n)!=EOF)
{
int i=0;
char a[10000];
getchar();
gets(a);
n=-n;
for(i=0;i<strlen(a);i++)
if(a[i]!=' ')
a[i]=(a[i]+n-'a'+26*2)%26+'a';
puts(a);
}
}
想了很久总算想出来了,大致思路是先把26个字母分别与0-25一一对应,然后加上26*a让所有数变成正数,a是多少都无所谓,只要让数都变成正数就行,题目n是(-50,50),所以a是2就够了,取余时要跟26对应,在加回'a'的ASCII码,26就是字母的范围,感觉这是个通法,可以发散到其他题目。