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’的取值范围,做好判断。
本文介绍了一种简单的密码加密算法,用于帮助小明找回他的1914小书童账户密码。密码通过将原字符串的每个字母向后移动n位形成,需处理边界情况确保字符范围在'a'到'z'之间。文章提供了C++代码实现,重点在于处理n的取值和字母的边界转换。
877

被折叠的 条评论
为什么被折叠?



