已知的最古老的一种加密技术是凯撒加密。该方法把一条消息中的每个字母用字母表中固定距离之后的那个字母来替代。如果越过了字母Z,会绕回到字母表的起始位置。例如,如果每个字母都用字母表中两个位置之后的字母代替,那么Y就被替换为A,Z就被替换为B。
编写程序用凯撒加密方法对消息进行加密。
注意:不是字母的字符不变,不改变字母的大小写。
第一行输入待加密的消息(不超过100个字符)。
第二行输入一个整数n(1<=n<=25)。表示每个字母都用字母表中 n 个位置之后的字母代替。
在一行中输出加密之后的消息。
Go ahead, make my day.
3
Jr dkhdg, pdnh pb gdb.
#include<stdio.h>
#include<ctype.h>
#include<string.h>
int main()
{char a[100];
gets(a);
int n=0;
scanf("%d",&n);
int i=0;
char b[26]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
int c=0;
c=strlen(a);
a[0]=a[0]+32;
while(i<c){
int d=0;
while(d<26){
if(a[i]==b[d]){
if((25-d)<n){
a[i]=b[d-1+n-25];
break;
}
else{
a[i]=b[d+n];
break;
}
}
d++;
}
i++;
}
a[0]=a[0]-32;
printf("%s",a);
return 0;
}