华为OJ基础篇-字符串加解密

本文介绍了一种简单的字符串加解密算法实现方法,对于英文字符通过前后移位及大小写转换来加密或解密,数字则通过加减1的方式进行变换。文中提供了具体的C++代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

1、对输入的字符串进行加解密,并输出。

2加密方法为:

当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a;

当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;

其他字符不做变化。

3、解密方法为加密的逆过程。

char JiaM(char x){
	char result = ' ';
	if (x<='9'&&x>='0'){
		if (x == '9'){ result = '0'; }
		else result =x+1;
		return result;

	}
   else if (x<='z'&&x>='a'){
		if (x == 'z'){ result = 'A'; }
		else result =x-'a'+1+'A';
		return result;
	}
   else if (x >= 'A'&&x <= 'Z'){
	   if (x == 'Z'){ result = 'a'; }
	   else result = x - 'A' + 1 + 'a';
	   return result;
   } else{}
}
char jieMi(char x){
	char result = ' ';
	if (x <= '9'&&x >= '0'){
		if (x == '0'){ result = '9'; }
		else result = x - 1;
		return result;
	}
	else if (x <= 'Z'&&x >= 'A'){
		if (x == 'A'){ result = 'z'; }
		else result = x - 'A' - 1 + 'z';
		return result;
	}
	else if (x >= 'a'&&x <= 'z'){
		if (x == 'a'){ result = 'Z'; }
		else result = x - 'a' - 1 + 'A';
		return result;
	} else{}
}
void HWoj(){
	string a = "ACDZZZZ",b,c;
	int len = a.length();
	char tmp;
	for (int i = 0; i < len; ++i){
		tmp = JiaM(a[i]);
		b.push_back(tmp);
	}
	cout << b << endl;
	for (int i = 0; i < len; ++i){
		tmp = jieMi(b[i]);
		c.push_back(tmp);
	}
	cout << c << endl;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值