**题目描述
将一段明文加密。加密的规则如下:将每个字符的ascii码的值减去24作为每个字符加密后的值,例如’a’的ascii码的值为97,那么加密后就变成了73。"73"就是’a’的密文。现在请你编写程序,对一段文字加密。请定义并使用如下函数:
void encrypt(char plain, char cipher)
{
//把原文字符串plain加密后存入字符串cipher
}
输入
输入一串字符串,只包含数字和字母,最长为200.
输出
输出加密后的字符串。
样例输入
zero12
样例输出
987790872526
提示
直接输出密文当然是最简单的方法,不过本题要求你将密文存入字符串(以备程序的其它模块使用)。
# include<stdio.h>
# include<string.h>
# include<stdlib.h>
void encrypt(char *plain, char *cipher);
int main(void)
{
char *str,*cipher;
int i;
str=(char *)malloc(sizeof(str)*210);
cipher=(char *)malloc(sizeof(char)*210);
gets(str);
encrypt(str,cipher);
for(i=0;i<strlen(cipher);i++)
{
printf("%d%d",cipher[i]/10,cipher[i]%10);
}
printf("\n");
return 0;
}
void encrypt(char *plain, char *cipher)
{
int len,i;
len=strlen(plain);
for(i=0;i<len;i++)
{
*(cipher+i)=*(plain+i)-24;
}
*(cipher+i)='\0';
}
相关摘要
(cipher+i)=(plain+i)-24;
指针变量名做加减运算对于编译器来说如cipher+1=cipher +sizeof(char);
指针 ptr 被加了 1,编译器是这样处理的:它把指针 ptr 的值加上了 sizeof(int),在 32 位程序中,是被加上了 4,因为在 32 位程序中,int 占 4 个字节。由于地址是用字节做单位的,故 ptr 所指向的地址由原来的变量 a 的地址向高地址方向增加了 4 个字节。
代码 2
# include<stdio.h>
# include<string.h>
# include<stdlib.h>
void encrypt(char *plain, char *cipher);
int main(void)
{
char *str,*cipher;
int i;
str=(char *)malloc(sizeof(str)*210);
cipher=(char *)malloc(sizeof(char)*210);
gets(str);
encrypt(str,cipher);
for(i=0;i<strlen(cipher);i++)
{
printf("%c",cipher[i]);
}
printf("\n");
return 0;
}
void encrypt(char *plain, char *cipher)
{
int len,i;
len=strlen(plain);
for(i=0;i<len;i++)
{
*(cipher+i)=*(plain+i)-24;
}
*(cipher+i)='\0';
}
代码 3
# include<stdio.h>
# include<string.h>
# include<stdlib.h>
int main(void)
{
char ch[210];
int i;
gets(ch);
for(i=0;i<strlen(ch);i++)
{
ch[i]=ch[i]-24;
}
ch[i]='\0';
printf("%s",ch);
return 0;
}
代码2和3当输入为"abcdef"时
输出均为"IJKLMN";
代码2和代码3的作用是解释printf("%d%d",cipher[i]/10,cipher[i]%10);为什么可以输出数字而不是字符加密后的字符。
如若不明白请认真看三个代码示例输出部分的变化。
如若有不明白可以私信我。
更多文章请查看博客https://blog.csdn.net/qq_45858803
如若对你有帮助三连击。