#include<stdio.h>
#include<stdlib.h>
void main()
{
int a;
char i,k;
printf("请选择功能:\n加密请输入:1\n解密输入:2\n");
scanf("%d",&a);k=getchar();
if(a==1)
{
printf("请输入加密内容\n");
for(;i!='\n';)
{
i=getchar();
if((i>64&&i<88)||(i>96&&i<120))
{
printf("%c",i+4);
}
else if((i>87&&i<91)||(i>119&&i<123))
{
printf("%c",i-25);
}
else
{
printf("%c",i);
}
}
}
if(a==2)
{
printf("请输入解密内容\n");
for(;i!='\n';)
{
i=getchar();
if((i>67&&i<90)||(i>99&&i<123))
{
printf("%c",i-4);
}
else if((i>64&&i<68)||(i>96&&i<100))
{
printf("%c",i+25);
}
else
{
printf("%c",i);
}
}
}
system("pause");
}
原理是利用ASCll码表将字符进行转换
在此过程中由于几处导致刚开始运行一直不成功
1.没有用
k=getchar();
来清除第一次输入1或2给a赋值的回车
导致i直接赋到上一个回车,直接结束进程。
2.
for(;i!='\n';)
被误写为
for(;getchar()!='\n';)
导致每次运行总发现会少一半的字符,原因就是在循环中,用getchar()直接判断,会消耗一个字符,这导致每次到给i赋值就少了一个字符。
3.
for(;i!='\n';)
被误写为
for(;i!='n';)
因为这个错误导致输入n时,便直接结束
但是也正是这样,我发现在不含n时,转换完所有字符,可再重新输入,再次转换,由此得到启发,只要不设置循环条件就可以多次使用转换功能