输入一个以回车符为结束标志的字符串(明文,少于80个字符)存放在字符数组s中,再输入一个正整数密钥n,将s中所有的大、小写字母用其后第n个字母替换,遇到“z”或者“Z”则向前折返到“a”或“A”,最后将加密后的字符串输出。
#include<stdio.h>
#include<string.h>
int main(){
int i,n,l;
char str1[80],str2[80];
char p;
gets(str1);
scanf("%d",&n);
l=strlen(str1);
for(i = 0; i<l; i++)
{
if(str1[i] >= 'A' && str1[i] <= 'Z')
str2[i] = (str1[i] - 'A' + n) % 26 + 'A';
else if(str1[i] >= 'a' && str1[i] <= 'z')
str2[i] = (str1[i] - 'a' + n) % 26 + 'a';
else if(str1[i]==' '||str1[i]=='!')
str2[i]=str1[i];
}
printf("%s", str2);
return 0;
}