蓝桥杯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
-
问题描述
相信经过这个学期的编程训练,大家对于字符串的操作已经掌握的相当熟练了。今天,徐老师想测试一下大家对于字符串操作的掌握情况。徐老师自己定义了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;
}
}
}
相关文章推荐
- 蓝桥杯 ALGO-143 算法训练 字符串变换
- 蓝桥杯 ALGO-48 算法训练 关联矩阵 (java)
- 蓝桥杯ALGO-5算法训练 最短路
- 蓝桥杯ALGO-92前缀表达式
- 蓝桥杯 algo_5 最短路 (bellman,SPFA)
- 蓝桥杯 - 算法训练 - ALGO-2 最大最小公倍数
- 蓝桥杯 ALGO-11算法训练 瓷砖铺放
- 蓝桥杯 ALGO-126 算法训练 水仙花
- 【备战蓝桥杯】【递归】【C语言】【ALGO-95算法训练 2的次幂表示】
- 蓝桥杯 - 算法训练 - ALGO - 5 最短路(spfa)
- 蓝桥杯 ALGO-91 Anagrams问题
- 蓝桥杯 ALGO-115 算法训练 和为T
- 蓝桥杯 ALGO-148 算法训练 5-1最小公倍数 java版
- 蓝桥杯 ALGO-50 算法训练 数组查找及替换
- 蓝桥杯 ALGO-101 算法训练 图形显示
- 蓝桥杯 ALGO-74 算法训练 连接字符串
- 蓝桥杯--ALGO-5 最短路
- 蓝桥杯ALGO-104——算法训练 阿尔法乘积
- 蓝桥杯 ALGO-86 矩阵乘法
- 蓝桥杯 ALGO-81 算法训练 动态数组使用