1171: 加密(指针专题)

1171: 加密(指针专题)
时间限制: 1 Sec 内存限制: 128 MB
提交: 1902 解决: 1339
[状态] [讨论版] [提交] [命题人:admin]
题目描述
将一段明文加密。加密的规则如下:将每个字符的ascii码的值减去24作为每个字符加密后的值,例如’a’的ascii码的值为97,那么加密后就变成了73。“73"就是’a’的密文,例如,字符串"abc”,在加密之后变为"737475",最后,整个密文再进行翻转,得到最终的密文"574737"。现在请你编写程序,对一段文字加密。请定义并使用如下函数:
void encrypt(char *plain, char *cipher)
{
//把原文字符串plain加密后存入字符串cipher
}

输入
输入一串字符串,只包含数字和字母,最长为200.

输出
输出加密后的字符串。

样例输入 Copy
zero12
样例输出 Copy
625278097789
提示
直接输出密文当然是最简单的方法,不过本题要求你将密文存入字符串(以备程序的其它模块使用)。

#include<stdio.h>
#include<string.h>
void encrypt(char *plain,char *cipher)
{
	int len1,i,j;
	len1=strlen(plain);
	for(i=0;i<len1;i++)
		*(plain+i)=*(plain+i)-24;
	for(i=len1-1,j=0;i>=0;i--,j+=2)
	{
			*(cipher+j)=*(plain+i)%10+'0';
			*(cipher+j+1)=*(plain+i)/10+'0';
	}
	*(cipher+2*len1)='\0';
}
int main()
{
	void encrypt(char *plain,char *cipher);
	char plain[200],cipher[400];
	scanf("%s",plain);
	encrypt(plain,cipher);
	printf("%s\n",cipher);
	return 0;
}

发布了104 篇原创文章 · 获赞 1 · 访问量 1145

猜你喜欢

转载自blog.csdn.net/YGGZZZ/article/details/104859262