1. 字母的ASCII 码在 ‘a’-‘z’和‘A’-‘Z’两个闭区间
2. 对于输入电文的每一个字符,判断是否落于两个区间;对于非区间的字符原样输出;对于区间内的,首先计算出字符在区间内的序号(从0开始),然后 序号 加1 并用 26(每个区间26个字母)取余,得出变换后的序号,然后将对应的字符输出。
例:
#include
using namespace std;
int main()
{
char str[]="adkflkjltAkjflad 1231 kjaf090AfB Cd De";
char * p = str;
while( *p != '\0')
{
if( *p >='a' && *p <='z')
*p = 'a' + ((*p - 'a') +1 ) % 26;
else if( *p >='A' && *p <='Z')
*p = 'A' + ((*p - 'A') +1 ) % 26;
p++;
}
cout << str << endl;
return 0;
}
int c,t;
while((c=getchar())!=\n)
{
if(c<='z'&&c>='a') t=c-'a';
else if(c<='Z'&&c>='A') t=c-'A';
else {putchar(c);continue;}
c-=t;
t=(t+1)%26;
c+=t;
putchar(c);
}
基本流程就是这样了 获取字符 判断 转换 输出
#include
#include
#include
using namespace std;
int main(void)
{
string line;
cout << "Please input:";
getline(cin,line);
for(int i = 0; i < line.size(); i++)
{
if(isalpha(line[i]))
{
if(line[i] >= 'a' &&line[i]<='z')
cout << char('a' + (line[i] - 'a' + 1) % 26);
else
cout << char('A' + (line[i] - 'A' + 1) % 26);
}
}
cout << endl;
return 0;
}