字符串变换

字符串变换

问题描述

  相信经过这个学期的编程训练,大家对于字符串的操作已经掌握的相当熟练了。今天,徐老师想测试一下大家对于字符串操作的掌握情况。徐老师自己定义了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,则不需要转换为缩写形式。

输入格式

  一共一行,分别是指代对应操作的数字和字符串,两者以空格分隔,字符串全部由英文字母组成

输出格式

  输出根据上述规则转换后对应的字符串

输入例子 1 

5 ABcdEE

输出例子 1

a-ee
 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 string a;
 4 vector<char> str;
 5 int k;
 6 
 7 void fun(int k)
 8 {
 9     switch (k)
10     {
11         case 1: transform(a.begin(), a.end(), a.begin(), ::toupper); break;
12         case 2: transform(a.begin(), a.end(), a.begin(), ::tolower); break;
13         case 3: reverse(a.begin(), a.end());break;
14         case 4:
15             for(int i = 0; i < a.size(); i ++)
16                 a[i] >= 'a' && a[i] <= 'z' ? a[i] -= 32 : a[i] += 32;
17             break;
18         case 5: 
19         {
20             transform(a.begin(), a.end(), a.begin(), ::tolower);
21             str.push_back(a[0]);
22             for (int i = 1; i < a.size(); i++)
23                 (a[i] - a[i - 1] == 1 && a[i + 1] - a[i] == 1 && i < a.size() - 1) ? str.push_back('-') : str.push_back(a[i]);
24             a.clear(); a.push_back(str[0]);
25             for(int i = 1; i < str.size(); i ++) if ((str[i] == '-' && str[i - 1] != '-') || str[i] != '-') a.push_back(str[i]);
26         }
27     }
28 }
29 
30 int main()
31 {
32     cin >> k >> a;
33     fun(k);
34     cout << a;
35     return 0;
36 }

 

posted @ 2020-09-17 00:07  。啊这  阅读(357)  评论(0)    收藏  举报