【华为OJ】 字符串加解密
2014-09-18 19:18
281 查看
描述: | 题目描述 1、对输入的字符串进行加解密,并输出。 2加密方法为: 当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a; 当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0; 其他字符不做变化。 3、解密方法为加密的逆过程。 接口描述: 实现接口,每个接口实现1个基本操作: void Encrypt (char aucPassword[], char aucResult[]):在该函数中实现字符串加密并输出 说明: 1、字符串以\0结尾。 2、字符串最长100个字符。 int unEncrypt (char result[], char password[]):在该函数中实现字符串解密并输出 说明: 1、字符串以\0结尾。 2、字符串最长100个字符。 |
知识点: | 字符串 |
题目来源: | 内部整理 |
练习阶段: | 初级 |
运行时间限制: | 10Sec |
内存限制: | 128MByte |
输入: | 输入说明 输入一串要加密的密码 输入一串加过密的密码 |
输出: | 输出说明 输出加密后的字符 输出解密后的字符 |
样例输入: | abcdefg BCDEFGH |
样例输出: | BCDEFGH abcdefg |
#include "stdio.h" #include "string.h" #include "ctype.h" void Change(char str[]) { int l=0, i=0, j=0; l = strlen(str); for (i = 0; i < l; i++) { if (isupper(str[i])) str[i] = (str[i] + 32 - 1 - 'a' + 26) % 26+'a'; else if (islower(str[i])) str[i] = (str[i] - 32 + 1 - 'A' + 26) % 26 + 'A'; else if (isdigit(str[i])) str[i] = (str[i] + 1 - '0' + 10) % 10 + '0'; } for (i = 0; i < l; i++) { printf("%c", str[i]); } printf("\n"); } int main() { char str1[1000],str2[1000]; gets(str1); gets(str2); Change(str1); Change(str2); return 0; }
相关文章推荐
- 华为oj 字符串加解密
- 华为OJ 字符串加解密
- 华为oj:字符串加解密
- 【华为 OJ 】字符串加解密
- 华为OJ 字符串加解密
- 华为OJ训练之0035-170112-字符串加解密
- [华为OJ] 字符串加解密
- 华为Oj基础第六题 字符串加解密
- 华为OJ(字符串加解密)
- 华为OJ——字符串加解密
- 华为OJ题目(八):字符串加解密
- 华为OJ——字符串加解密
- 华为OJ题库_字符串加解密
- 华为OJ平台试题 —— 字符串:字符串加解密
- 华为OJ平台题:字符串加解密
- 华为OJ:字符串加解密
- [华为OJ--C++]023-字符串加解密
- 华为OJ 初级:字符串加解密
- 华为OJ 初级:字符串加解密
- 华为OJ基础篇-字符串加解密