/* 算法训练 字符串变换
时间限制:1.0s 内存限制:256.0MB
问题描述
相信经过这个学期的编程训练,大家对于字符串的操作已经掌握的相当熟练了。今天,徐老师想测试一下大家对于字符串操作的掌握情况。徐老师自己定义了1,2,3,4,5这5个参数分别指代不同的5种字符串操作,你需要根据传入的参数,按照徐老师的规定,对输入字符串进行格式转化。
徐老师指定的操作如下:
1 表示全部转化为大写字母输出,如abC 变成 ABC
2 表示全部转换为小写字母输出,如abC变成abc
3 表示将字符串整个逆序输出,如 abc 变成 cba
4 表示将字符串中对应的大写字母转换为小写字母,而将其中的小写字母转化为大写字母输出,如 abC变成ABc
5表示将全部转换为小写字母,并将其中所有的连续子串转换为对应的缩写形式输出,比如abcD 转换为a-d,其次,-至少代表1个字母,既如果是ab,则不需要转换为缩写形式。
输入格式
一共一行,分别是指代对应操作的数字和字符串,两者以空格分隔,字符串全部由英文字母组成
输出格式
输出根据上述规则转换后对应的字符串
样例输入
5 ABcdEE
样例输出
a-ee
数据规模和约定
输入字符串长度最长为200。
*/
#include<iostream>
#include<cctype>
using namespace std;
int main()
{
int n;
cin >> n;
string s;
cin >> s;
int len = s.length();
switch (n)
{
case 1:
case 2:
case 4:
for(int i = 0 ; i < len ; i++)
{
if(n == 1) s[i] = toupper(s[i]);//转换成大写
if(n == 2) s[i] = tolower(s[i]);//转换成小写
else
{
if(isupper(s[i])) s[i] = tolower(s[i]);//大转小
else s[i] = toupper(s[i]);//小转大
}
}
cout << s;
break;
case 3:
for(int i = len - 1 ; i >= 0 ; i--)//逆序输出
cout << s[i];
break;
case 5:
string t;
for(int i = 0; i < len; i++)
s[i] = tolower(s[i]);
for(int i = 0; i < len; i++)
{
if(i == 0)
t += s[0];
else if(i != len - 1)
{
if(s[i] != s[i - 1] + 1 || s[i] != s[i + 1] - 1)
t += s[i];
else if(t[t.length() - 1] != '-')
t += '-';
}
else
t += s[i];
}
cout << t;
break;
}
}
蓝桥杯练习系统-字符串变换
最新推荐文章于 2022-04-12 00:59:41 发布