电文环形解密 (C语言)
电文环形解密 (10 分)
将26个英文字母按顺时针方向排成一个圆环。**是一个整数。
加密的方法:
- 若** key≥0,则从明文字母开始按顺时针方向走 ∣key∣ 步得到密文字母;
- 若** key<0,则从明文字母开始按逆时针方向走 ∣key∣ 步得到密文字母。
请编写解密程序,输入**(任意整数)和密文电文(含大、小写字母,数字和其他符号),对电文中的大、小写字母进行解密,并输出明文电文。
输入格式
**(任意整数)
密文电文(以回车结束)
输出格式
明文电文(以回车结束)
输入样例1
2
K nqxg aqw!
输出样例1
I love you!
输入样例2
-2
G fytc 10 zyeq.
输出样例2
I have 10 bags.
代码实现
#include <stdio.h>
int main(){
//为了防止之后字符的值超过char的取值范围,将c定义成无符号的char类型
unsigned char c;
int n;
scanf("%d", &n);
n %= 26; //使n的值在26以内
getchar();
//由于要先给c赋值之后才能进行判断,故使用do-while循环
do{
scanf("%c", &c);
if(c >= 'a' && c <= 'z'){
c -= n;
//这里使用了问号表达式,不了解的自行百度
c > 'z' ? c -= 26:(c < 'a' ? c += 26 : c);
}
if(c >= 'A' && c <= 'Z'){
c -= n;
c > 'Z' ? c -= 26:(c < 'A' ? c += 26 : c);
}
printf("%c", c);
}while(c != '\n');
return 0;
}