【华为OJ】 字符串加解密
来源:互联网 发布:数据变换方法的选择 编辑:程序博客网 时间:2024/06/05 09:37
描述:
题目描述
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输入:
输入说明
输入一串要加密的密码
输入一串加过密的密码
输出说明
输出加密后的字符
输出解密后的字符
abcdefgBCDEFGH样例输出:
BCDEFGHabcdefg
#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;}
0 0
- 【华为OJ】 字符串加解密
- 华为OJ 字符串加解密
- 华为oj: 字符串加解密
- 华为oj字符串加解密
- 华为oj:字符串加解密
- 华为oj 字符串加解密
- [华为OJ] 字符串加解密
- 【华为OJ】字符串加解密
- 【华为 OJ 】字符串加解密
- 华为OJ 字符串加解密
- 华为OJ 字符串加解密
- 华为OJ(字符串加解密)
- 华为OJ题库_字符串加解密
- 华为OJ平台题:字符串加解密
- 华为OJ基础篇-字符串加解密
- 【华为OJ】【023-字符串加解密】
- 华为OJ——字符串加解密
- 华为OJ 初级:字符串加解密
- 第六章、Linux 的文件权限与目录配置
- 华为机试:元素异同比较
- BZOJ1578 USACO 2009 Feb Gold 2.Stock Market
- XML数据解析
- 1003. 我要通过!(20) (ZJUPAT 模拟)
- 【华为OJ】 字符串加解密
- 数据结构
- Busybox功能在Ubuntu上的测试
- 如何将十进制数转换成二进制数输出的一种方法
- 交朋友---2014亚马逊机试第1题
- 优先队列 之 堆排序实现(堆排序思想)
- 线段树模板-成段增减
- 泛型
- IOS开发 单例模式