题目背景
某蒟蒻迷上了“小书童”,有一天登陆时忘记密码了(他没绑定邮箱or手机),于是便把问题抛给了神犇你。
题目描述
蒟蒻虽然忘记密码,但他还记得密码是由一串字母组成。且密码是由一串字母每个向后移动n为形成。z的下一个字母是a,如此循环。他现在找到了移动前的那串字母及n,请你求出密码。(均为小写)
输入输出格式
输入格式:
第一行:n。第二行:未移动前的一串字母
输出格式:
一行,是此蒟蒻的密码
输入输出样例
输入样例#1: 复制
1
qwe
输出样例#1: 复制
rxf
说明
字符串长度<=50
#include <stdio.h>
int main()
{
char in[100];
int n, j;
scanf("%d%s", &n, in); //读入
for(j = 0; in[j] != '\0'; j++)
putchar((in[j]-'a'+n)%26+'a');
//in[j]-'a':读入中对应的第几个字母的位置,比如'a'对应0,'b'对应1,'c'对应2(0开始);
//in[j]-'a'+n:读入中对应字母加上转移位数得到的字母的对应位置。
//比如说'c'这个字母移动3位,就是第2个字母向右移动3个,就是第五个字母,即'f'
//取余26是防止移动位数超过26导致炸掉
//再加上'a',将对应位置还原成字母,再打出来
}
转载洛谷