蓝桥杯 ALGO-143 字符串变换 java

问题描述

资源限制
时间限制: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。

参考代码

package 字符串变换;

import java.util.Scanner;

public class Main {
public static void main(String[] args) {
	Scanner sr = new Scanner(System.in);
	int n =sr.nextInt();
	String s = sr.next();
	switch (n) {
	case 1:
		// 1 表示全部转化为大写字母输出,如abC 变成 ABC
		System.out.println(s.toUpperCase());
		break;
	case 2:
		// 2 表示全部转换为小写字母输出,如abC变成abc
		System.out.println(s.toLowerCase());
		break;
	case 3:
		// 3 表示将字符串整个逆序输出,如 abc 变成 cba
		StringBuilder sb = new StringBuilder(s);
		sb.reverse();
		System.out.println(sb);
		break;
	case 4:
		// 4 表示将字符串中对应的大写字母转换为小写字母,而将其中的小写字母转化为大写字母输出,如 abC变成ABc
		System.out.println(dx(s));
		break;
	case 5:
		// 5表示将全部转换为小写字母,并将其中所有的连续子串转换为对应的缩写形式输出,比如abcD 转换为a-d,其次,-至少代表1个字母
		System.out.println(f(s));
		break;
	}
}

private static String f(String text) {
	text = text.toLowerCase();//先转换小写
	char[] arr = text.toCharArray();//转换为数组
	//遍历这个数组枚举起点位置
	for (int i = 0; i < arr.length; i++) {
		int star = i;
		int step = 0;//abcdeE
		//以这个位置为起点看看是否连续
		for (int j = star; j < arr.length-1; j++) {
			if (arr[j] - arr[j+1] == -1)
				step++;//连续,步数+1
			else 
				break;//不连续跳出
		}
		if (step >= 2) {
			//将连续的这段替换为'-'
			for (int j = i+1; j < i+step; j++) {
				arr[j] = '-';
			}
		}
	}
	//将连续'-'缩短为1个
	StringBuilder sb = new StringBuilder();
	for (int i = 0; i < arr.length; i++) {
		if (arr[i]!='-') {
			sb.append(arr[i]);
		}else if(sb.charAt(sb.length()-1)=='-' && arr[i]!='-'){
			sb.append(arr[i]);
		}else if (sb.charAt(sb.length()-1)!='-') {
			sb.append(arr[i]);
		}
	}
	//将处理完的字串返回
	return sb.toString();
}

private static String dx(String text) {
	String ruselt = "";
	char [] s1 = text.toCharArray();
	//接受的字符串转化为数组W
	for (int i = 0; i < s1.length; i++) {
		//判断每个字符,大写转小写,小写转大写
		if( s1[i] >='a'&&s1[i] <='z' ){
			//ask码大小写差值32,小转大-32,大专小+32
			ruselt+=((char)(s1[i]-32));
		}
		else if( s1[i] >='A'&&s1[i] <='Z' ){
			//大写的话
			ruselt+=((char)(s1[i]+32));
		}
	}
	return ruselt;
}
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一条小传传

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

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

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

打赏作者

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

抵扣说明:

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

余额充值