蓝桥杯——算法训练 字符串变换(Vip试题)

来源:互联网 发布:vs for mac离线安装包 编辑:程序博客网 时间:2024/05/08 07:31

本人小白,代码写的比较简单,适合新手看。用c写的。
定义都比较简单,没有什么实际意义,如有不懂得可以私信我!
欢迎指点!

这是蓝桥杯练习系统的试题。代码提交测试为100分。
运用的软件是 Dev -C++。(下载地址
http://xueyuan.lanqiao.org/upload/ueditor/php/upload/file/20161107/1478502584857555.rar)

这里写图片描述


问题描述
  相信经过这个学期的编程训练,大家对于字符串的操作已经掌握的相当熟练了。今天,徐老师想测试一下大家对于字符串操作的掌握情况。徐老师自己定义了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 <stdio.h>#include <string.h>int main(){    char a,c[201];    scanf("%d %s",&a,&c);    int cl,i;    cl=strlen(c);    if(a==1)    {        for(i=0;c[i];i++)            if(c[i]>='a'&&c[i]<='z')                c[i]-=32;        printf("%s",c);    }    else if(a==2)    {        for(i=0;c[i];i++)            if(c[i]>='A'&&c[i]<='Z')                c[i]+=32;        printf("%s",c);    }    else if(a==3)    {        for(i=cl-1;i>=0;i--)        {            printf("%c",c[i]);        }    }    else if(a==4)    {        i=0;        while(c[i]!= '\0')        {            if(c[i]>96)            {                c[i]=c[i]-32;            }            else            {                c[i]=c[i]+32;            }            i++;        }        printf("%s",c);    }    else if(a==5)    {        i=0;        while(c[i]!= '\0')        {            c[i]=c[i]<96?c[i]+32:c[i];            i++;        }        if(cl>2)        {            i=0;            int b,e;            while(c[i]!= '\0')            {                if(c[i]+1==c[i+1]&&c[i]-1!=c[i-1]&&c[i+1]+1==c[i+2])                {                    printf("%c-",c[i]);                }                else if(c[i]+1!=c[i+1]&&c[i]-1==c[i-1])                {                    printf("%c",c[i]);                }                else if(c[i]+1!=c[i+1]||c[i]-1!=c[i-1])                {                    printf("%c",c[i]);                }                i++;            }        }        else        {            printf("%s",c);        }    }    return 0;}
0 0
原创粉丝点击