有一行电文,已经按照如下规则译成了密码:
A->Z a->z
B->Y b->y
C->X c->x
… …
… …
即第1个字母变换成第26个字母,第i个字母变换成第(26-i+1)个字母。非字母字符不变。给定一段密码,请将其译成原文并输出。
#include#define n 100 char str[n]; void niuma(); void main() { gets_s(str); niuma(); printf("%s", str); } void niuma() { //不用管空格和其他字符,不满足选择分支还会保留 for (int i = 0;str[i]!=' '; i++) { //用中间第十三个作为分界;算法就两个大小写转换就行‘M’-str[i]是得到第几位然后对应到后面半个的位置 if (str[i] >= 'A' && str[i] <= 'M') { str[i] = 'M' - str[i] + 'M' + 1; } //十三个以后同样 else if (str[i] > 'M' && str[i] <= 'Z') { str[i] = 'Z' - str[i] + 'A'; } else if (str[i] >= 'a' && str[i] <= 'm') { str[i] = 'm' - str[i] + 'm' + 1; } else if (str[i] > 'm' && str[i] <= 'z') { str[i] = 'z' - str[i] + 'a'; } } }
样例输入:R zn z kiltizn.
输出:



