C++信息学奥赛1137:加密的病历单

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main() {
	string arr;
	// 输入一行字符串
	getline(cin, arr);
	string btt;
	for(int i=arr.length()-1;i>=0;i--){
		char a=arr[i]+3; // 对当前字符进行加密,向后移动三位
		if(arr[i]>=88 and arr[i]<=90) { // 如果当前字符是'X'、'Y'、'Z'中的一个
			a=arr[i]-23; // 解密时向前移动23位
		}else if(arr[i]>=120 and arr[i]<=122){ // 如果当前字符是'x'、'y'、'z'中的一个
			a=arr[i]-23; // 解密时向前移动23位
		}
		if(a>90){ // 如果加密后的字符超过了大写字母范围
			a-=32; // 将其转换为小写字母
			cout<<a; // 输出解密后的字符
		}else{
			a+=32; // 将加密后的字符转换为大写字母
			cout<<a; // 输出解密后的字符
		}
	}
	return 0;
}

该段代码实现了一个简单的字符加密和解密功能。首先,通过getline(cin, arr)语句从标准输入读取一行字符串。然后,从字符串的最后一个字符开始,向前遍历。对于每个字符,使用char a=arr[i]+3将其往后移动三位。如果字符是大写字母'X'、'Y'、'Z'中的一个,则将其解密后的字符设为原字符减去23;如果字符是小写字母'x'、'y'、'z'中的一个,则同样将其解密后的字符设为原字符减去23。如果加密后的字符超过了大写字母范围,则将其转换为小写字母;否则,将其转换为大写字母。最后,输出解密后的字符。

相关推荐
再睡一夏就好5 分钟前
【C++闯关笔记】unordered_map与unordered_set的底层:哈希表(哈希桶)
开发语言·c++·笔记·学习·哈希算法·散列表
mjhcsp6 分钟前
C++ 贪心算法(Greedy Algorithm)详解:从思想到实战
c++·ios·贪心算法
potato_155410 分钟前
现代C++核心特性——内存篇
开发语言·c++·学习
lly20240612 分钟前
C# 继承
开发语言
August_._13 分钟前
【JAVA】基础(一)
java·开发语言·后端·青少年编程
李白的粉37 分钟前
基于springboot的新闻资讯系统
java·spring boot·毕业设计·课程设计·源代码·新闻资讯系统
软件开发技术深度爱好者37 分钟前
Python类中方法种类介绍
开发语言·python
麦麦鸡腿堡37 分钟前
Java_LinkedList底层结构
java·开发语言
沐怡旸39 分钟前
【穿越Effective C++】条款13:以对象管理资源——RAII原则的基石
c++·面试
whatever who cares1 小时前
android/java中gson的用法
android·java·开发语言