蓝桥杯练习系统-字符串变换

/*  算法训练 字符串变换
 时间限制: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;
    }
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Αиcíеиτеǎг

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值