c语言简单编程,密码译成原文
有一行电文,已按下面规律译成密码:A->ZB->YC->X...a->zb->yc->x..即第一个字母编成第26个字母,第i个字母变成第(26-i+1)个字母。非字母字...
有一行电文,已按下面规律译成密码:A->Z B->Y C->X ...
a->z b->y c->x ..即第一个字母编成第26个字母,第i个字母变成第(26-i+1)个字母。非字母字符不变。编程输出密码和原文。加注释哦! 展开
a->z b->y c->x ..即第一个字母编成第26个字母,第i个字母变成第(26-i+1)个字母。非字母字符不变。编程输出密码和原文。加注释哦! 展开
4个回答
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main()
{
char es[200];
int l;
int n;
char end;
scanf("%s",es);
l=strlen(es);
end=es[l-1];
l--;
n=end-'a'+1;
int direct=-1;
int m;
char c;
//printf("to enterfor.");
for(m=0;m<l;m++)
{
c=es[m];
if(c>='a' && c<='z')
{
//printf("%c enteraz",c);
if(direct==1)
{
c+=n;
if(c>'z')
{
c=c-'z'+'a';
}
}
else
{
c-=n;
if(c<'a')
{
c='z'-('a'-c);
}
}
direct*=-1;
}
if(c>='A' && c<='Z')
{
if(direct==1)
{
c+=n;
if(c>'Z')
{
c=c-'Z'+'A';
}
}
else
{
c-=n;
if(c<'A')
{
c='Z'-('A'-c);
}
}
direct*=-1;
}
//putchar(c);
printf("%c",c);
}
return 0;
}
#include <stdlib.h>
#include <string.h>
int main()
{
char es[200];
int l;
int n;
char end;
scanf("%s",es);
l=strlen(es);
end=es[l-1];
l--;
n=end-'a'+1;
int direct=-1;
int m;
char c;
//printf("to enterfor.");
for(m=0;m<l;m++)
{
c=es[m];
if(c>='a' && c<='z')
{
//printf("%c enteraz",c);
if(direct==1)
{
c+=n;
if(c>'z')
{
c=c-'z'+'a';
}
}
else
{
c-=n;
if(c<'a')
{
c='z'-('a'-c);
}
}
direct*=-1;
}
if(c>='A' && c<='Z')
{
if(direct==1)
{
c+=n;
if(c>'Z')
{
c=c-'Z'+'A';
}
}
else
{
c-=n;
if(c<'A')
{
c='Z'-('A'-c);
}
}
direct*=-1;
}
//putchar(c);
printf("%c",c);
}
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-11-24
展开全部
可以说这种是不可逆的,因为你不懂是变化后的还是没变化以后的字符。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-11-24
展开全部
是用户输入密文然后程序输出原文吗?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2013-11-24
展开全部
暴力解密!
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |