凯撒密码是一种非常古老的加密方法,相传当年凯撒大地行军打仗时为了保证自己的命令不被敌军知道,就使用这种特殊的方法进行通信,以确保信息传递的安全。他的原理很简单,说到底就是字母于字母之间的替换。下面让我们看一个简单的例子:“baidu”用凯撒密码法加密后字符串变为“edlgx”,它的原理是什么呢?把“baidu”中的每一个字母按字母表顺序向后移 3 位,所得的结果就是刚才我们所看到的密文。 /**凯撒密码实现 要求,将明文字母变成它后面第三个字母,后面的循环到前面! 公式为f(a)=(f(a)+3)%26 */ #include int main() { char P[100];/*定义明文长度*/ char C[100];/*定义密文长度*/ int K=3,i; printf("Please input Plaintext:\n"); /*输入明文*/ gets(P); /* 接受明文*/ for(i=0;P[i]!='\0';i++) { /*逐个判断字母的大小*/ if(P[i]>='a'&&P[i]<='z') /*小写字母 */ C[i]=(P[i]-'a'+K)%26+'a'; else if(P[i]>='A'&&P[i]<='Z')/*大写字母 */ C[i]=(P[i]-'A'+K)%26+'A'; else C[i]=' ';/*如果不是字母,转换为空格*/ } printf("The Ciphertext is :\n%s\n",C);/*输出密文*/ getch(); return 0; } 1、程序结构化,用函数分别实现 2、对文件的加密,解密输出到文件 #include #include void menu()/*菜单,1.加密 2.解密 3.退出*/ { clrscr(); printf("\n==============================================================================="); printf("\n1.Encrypt the file"); printf("\n2.Decrypt the file"); printf("\n3.Quit\n"); printf("===============================================================================\n"); printf("Please select a item:"); return; } char encrypt(char ch,int n)/*加密函数,把字符向右循环移位n*/ { while(ch>='A'&&ch<='Z') { return ('A'+(ch-'A'+n)%26); } while(ch>='a'&&ch<='z') { return ('a'+(ch-'a'+n)%26); } return ch; } main() { int i,n; char ch0,ch1; FILE *in,*out; char infile[10],outfile[10]; textbackground(RED); textcolor(LIGHTGREEN); clrscr(); menu(); ch0=getch(); while(ch0!='3') { if(ch0=='1') { clrscr(); printf("\nPlease input the infile:"); scanf("%s",infile);/*输入需要加密的文件名*/ if((...