题目:
为使电文保密,往往按一定规律将其转换成密码,收报人再根据规律将其译回原文
解题思路:
我的想法效仿循环队列的思想,把上图的圆在代码中实现成为一个真正的字母表圆,当输入的字符为w的时候,w的译文会在这个字母圆中转为开头的a
#include<stdio.h> #include<string.h> char change(char before,char begin,char end) { char after=before+4;//首先将当前字符转为后面第4个 if(after>end)//如果出现溢出这个字母圆的情况,就要对溢出的情况进行处理 { int gap=after-end-1;//求出溢出的间隙大小,例如m+4是91,而a是90,间隙为91-90-1=0 after=begin+gap;//则这个的译文为a/A+0 } return after; } int main() { char word[]="Wonderful!"; for(int i=0;i<strlen(word);i++){ if(word[i]>='a'&&word[i]<='z') printf("%c",change(word[i],'a','z')); else if(word[i]>='A'&&word[i]<='Z') printf("%c",change(word[i], 'A','Z')); else printf("%c",word[i]); } printf(" "); }
当然还有简单的方法,可以直接参考书上,我这里就不再赘述了