题目描述
在传递信息的过程中,为了加密,有时需要按一定规则将文本转换成密文发送出去。有一种加密规则是这样的:
将字母转换成其后的第3个字母,例如:A→D,a→d;对于字母表的最后3个字母,将其相应转化为字母表前3个字母,例如X→A,x→a。
对于非字母字符,保持不变。
现在,请你根据输入的一行字符,输出其对应的密码。
输入
输入一个字符串。字符串长度不超过 100。
输出
输出加密后的字符串。
样例输入 复制
I(2016)love(08)China(15)!
样例输出 复制
L(2016)oryh(08)Fklqd(15)!
#include<bits/stdc++.h>
using namespace std;
int main() {
/*
除了下面的方法,当然还可以分情况讨论
*/
string s;
cin>>s;
for(int i=0; i<s.size(); i++) {
if(s[i]>='A'&&s[i]<='Z') {
s[i]='A'+(s[i]+3-'A')%26;//(s[i]+3-'A')%26实现索引从0开始,找到+3后对应字符偏移量,%运算实现在26个字母内循环
}
if(s[i]>='a'&&s[i]<='z') {
s[i]='a'+(s[i]+3-'a')%26;
}
}
cout<<s<<endl;
return 0;
}
3405:练69.5 恺撒加密术
题目描述
加密术最早应用于古代战争。古罗马时期,凯撒大帝曾是使用密码来传递信息,它是一种替代密码,对于信中的每个字母,会用它后面第i给字母代替。试编一个程序,将输入的一段英文字符加密后输出,只加密字母,加密的规则是用字母后来的第1个字母代替用来的字母,即用’�b’代替’�a’,用’�c’代替’�b’,······,用’�a’代替’�z’。
输入
一行字符串。
输出
加密后的字符串。
样例输入 复制
Nike is excellent!
样例输出 复制
Ojlf jt fydfmmfou!
#include<bits/stdc++.h>
using namespace std;
int main() {
/*
除了下面的方法,当然还可以分情况讨论
*/
string s;
getline(cin,s);//cin默认会在遇到空格、制表符或换行符时停止读取 ,用getline读取一行
for(int i=0; i<s.size(); i++) {
if(s[i]>='A'&&s[i]<='Z') {
s[i]='A'+(s[i]+1-'A')%26;//(s[i]+3-'A')%26实现索引从0开始,找到+3后对应字符偏移量,%运算实现在26个字母内循环
}
if(s[i]>='a'&&s[i]<='z') {
s[i]='a'+(s[i]+1-'a')%26;
}
}
cout<<s<<endl;
return 0;
}