1914 小书童——密码
小明迷上了“小书童”,有一天登陆时忘记密码了(他没绑定邮箱or手机),于是便把问题抛给了你。小明虽然忘记密码,但他还记得密码是由一个字符串组成。密码是由原文字符串(由不超过 50 个小写字母组成)中每个字母向后移动 n 位形成的。z 的下一个字母是 a,如此循环。他现在找到了移动前的原文字符串及 n,请你求出密码。
输入格式
第一行:n。
第二行:未移动前的一串字母
输出格式
一行,是此小明的密码
输入输出样例
输入
1
qwe
输出
rxf
代码的实现
#include<iostream>
#include<cstring>
using namespace std;
int main(){
int n;
char a[50];
cin>>n>>a;
while(n>=26)n-=26; //将n保持在26以内
for(int i=0;i<strlen(a);i++){
if(a[i]+n>'z'){ //判断是否超出‘z’的界限
a[i]=a[i]+n-26;
}
else a[i]=a[i]+n;
}
cout<<a<<endl;
return 0;
}
注意事项
该题目最主要的就是要注意n的取值和从’a’到’z’的取值范围,做好判断。