您的位置:首页 > 编程语言 > Go语言

蓝桥杯ALGO3——143

2018-03-26 13:05 127 查看
算法训练 字符串变换

问题描述

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

-

第一种方法:使用if-else语句

import java.util.Scanner;

public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();//表示输入的对应操作数的数字
String str = sc.next();//表示输入的字符串

String str1;
if(n == 1) {
//1 表示全部转化为大写字母输出,如abC 变成 ABC
str1 = str.toUpperCase();
System.out.println(str1);
}
else if(n ==2) {
//2 表示全部转换为小写字母输出,如abC变成abc
str1 = str.toLowerCase();
System.out.println(str1);

}
else if(n ==3) {
//3 表示将字符串整个逆序输出,如 abc 变成 cba
char ch[] = new char[str.length()];//定义一个str.length()长度的数组
char []str2 = str.toCharArray();//将str字符串转化为字符并存放在str2数组里面
for (int i = 0;i<str.length();i++) {
// char []str2 = str.toCharArray();
ch[i] = str2[str.length()-i-1];
System.out.print(ch[i]);
}

}
else if (n == 4) {
//4 表示将字符串中对应的大写字母转换为小写字母,而将其中的小写字母转化为大写字母输出,如 abC变成ABc
char str2,str3;
for(int i = 0;i<str.length();i++) {
str2 = str.charAt(i);
//System.out.println(str2);
if(str2 <='z' && str2 >='a') {
str3 = (char) (str2-32);
}
else{
str3 = (char)(str2+32);
}
System.out.print(str3);
}
}
else if  (n ==5) {
//5表示将全部转换为小写字母,并将其中所有的连续子串转换为对应的缩写形式输出,比如abcD 转换为a-d,其次,-至少代表1个字母,
//既如果是ab,则不需要转换为缩写形式。
str = str.toLowerCase();//将所有字母转化为小写

for(int i = 0;i<str.length();i++) {
int count = 1;
for(int j = i+1;j<str.length();j++) {
if(str.charAt(j) - str.charAt(i) == j-i) {//判断是否连续
count++;
}
else
break;
}
if(count > 2) {//如果满足连续字符超多三个
str = str.replace(str.substring(i,i+count), str.charAt(i) + "-" + str.charAt(i + count -1));
//replace(i,j)函数表示将i替换为j
//                  public String substring(int beginIndex, int endIndex)
//                  第一个int为开始的索引,对应String数字中的开始位置,
//                  第二个是截止的索引位置,对应String中的结束位置
//                  1、取得的字符串长度为:endIndex - beginIndex;
//                  2、从beginIndex开始取,到endIndex结束,从0开始数,其中不包括endIndex位置的字符
}
}
System.out.print(str);

}
else {

}
}

}


第二种方法:使用switch -case语句

import java.util.Scanner;

public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();//表示输入的对应操作数的数字
String str = sc.next();//表示输入的字符串

String str1;
switch(n) {
case 1:
{
str1 = str.toUpperCase();
System.out.println(str1);
break;
}

case 2:
{
str1 = str.toLowerCase();
System.out.println(str1);
break;
}
case 3:
{
//3 表示将字符串整个逆序输出,如 abc 变成 cba
char ch[] = new char[str.length()];//定义一个str.length()长度的数组
char []str2 = str.toCharArray();//将str字符串转化为字符并存放在str2数组里面
for (int i = 0;i<str.length();i++) {
// char []str2 = str.toCharArray();
ch[i] = str2[str.length()-i-1];
System.out.print(ch[i]);
}
break;
}

case 4:
{
//4 表示将字符串中对应的大写字母转换为小写字母,而将其中的小写字母转化为大写字母输出,如 abC变成ABc
char str2,str3;
for(int i = 0;i<str.length();i++) {
str2 = str.charAt(i);
//System.out.println(str2);
if(str2 <='z' && str2 >='a') {
str3 = (char) (str2-32);
}
else{
str3 = (char)(str2+32);
}
System.out.print(str3);
}
break;
}

case 5:
{
str = str.toLowerCase();
//char str2[] = str.toCharArray();

for(int i = 0;i<str.length();i++) {
int count = 1;
for(int j = i+1 ;j <str.length();j++) {

if(str.charAt(j) - str.charAt(i) == j - i) {
count ++;
}
else
break;
}
if(count > 2) {
str = str.replace(str.substring(i, i + count), str.charAt(i) + "-" + str.charAt(i+count-1));
}
}
System.out.println(str);
break;
}

default :
break;

}

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  蓝桥杯-java