java: string transformation

java: string transformation

topic

问题描述
  相信经过这个学期的编程训练,大家对于字符串的操作已经掌握的相当熟练了。今天,徐老师想测试一下大家对于字符串操作的掌握情况。徐老师自己定义了1,2,3,4,55个参数分别指代不同的5种字符串操作,你需要根据传入的参数,按照徐老师的规定,对输入字符串进行格式转化。
  徐老师指定的操作如下:
  1 表示全部转化为大写字母输出,如abC 变成 ABC
  2 表示全部转换为小写字母输出,如abC变成abc
  3 表示将字符串整个逆序输出,如 abc 变成 cba
  4 表示将字符串中对应的大写字母转换为小写字母,而将其中的小写字母转化为大写字母输出,如 abC变成ABc
  5表示将全部转换为小写字母,并将其中所有的连续子串转换为对应的缩写形式输出,比如abcD 转换为a-d,其次,-至少代表1个字母,既如果是ab,则不需要转换为缩写形式。
输入格式
  一共一行,分别是指代对应操作的数字和字符串,两者以空格分隔,字符串全部由英文字母组成
输出格式
  输出根据上述规则转换后对应的字符串
样例输入
5 ABcdEE
样例输出
a-ee
数据规模和约定
  输入字符串长度最长为200

Use knowledge

java.lang.Character.isLowerCase (char ch) Determines whether the specified character is a lowercase letter.

字符是小写如果是一般性类型,Character.getType(ch)所提供为LOWERCASE_LETTER,或为属性Other_Lowercase Unicode的标准定义。//原文出自【易百教程】,商业转载请联系作者获得授权,非商业请保留原文链接:https://www.yiibai.com/java/lang/character_islowercase.html

Here Insert Picture Description

Code

import java.util.Scanner;


public class 字符串变换 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();//输入数字
		String s=sc.next();//输入字符,如果是nextLine会有前面的空格
		StringBuffer str=new StringBuffer(s);//创建StringBuffer对象
		switch(n){
		case(1):
			capital(s);
			
		case(2):
			minuscules(s);
		case(3):
			backWard(str);
		case(4):
			change(str);
		case(5):
			connect(s);
		}
	}
	public static void capital(String s){//小写转换为大写
		s=s.toUpperCase();//小写转换为大写
		System.out.println(s);
	}
	public static void minuscules(String s){//大写转换为小写
		s=s.toLowerCase();
		System.out.println(s);
	}
	public static void backWard(StringBuffer str){
		str.reverse();//翻转
		System.out.println(str);//输出逆序
	}
	public static void change(StringBuffer str){//大小写转换
		for(int i=0;i<str.length();i++){
			if(Character.isLowerCase(str.charAt(i))){//是否为小写字母
				str.setCharAt(i, Character.toUpperCase(str.charAt(i)));//转换为大写字母
			}else{
				str.setCharAt(i, Character.toLowerCase(str.charAt(i)));
			}
		}
		System.out.println(str);
	}
	public static void connect(String s){//最后一个
		s=s.toLowerCase();//全部化为小写
		StringBuffer st=new StringBuffer();
		for(int i=0;i<s.length();i++){
			if(i==0)//如果为0时
				st =st.append(s.charAt(0));
			else if(i !=s.length()-1){//如果i的不只为2个数字,或不为倒数第二个数
				if((int)s.charAt(i) !=(int)s.charAt(i-1)+1 || (int)s.charAt(i) != (int)s.charAt(i+1)-1){
					st =st.append(s.charAt(i));
				}else if(st.charAt(st.length()-1)!='-'){
					st =st.append('-');
				}
			}else
				st =st.append(s.charAt(i));
		}
		System.out.print(st);
	}
	
}

Note that this problem with the code switch statement in writing
, for example,

1 adfDfkkkDD

输出
ADFDFKKKDD
adfdfkkkdd
DDkkkfDfda
ddKKKFdFDA
adfdfkkkdd

Correct codes

import java.util.Scanner;


public class 字符串变换 {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();//输入数字
		String s=sc.next();//输入字符,如果是nextLine会有前面的空格
		StringBuffer str=new StringBuffer(s);//创建StringBuffer对象
		switch(n){
		case(1):
			capital(s);
			break;
		case(2):
			minuscules(s);
			break;
		case(3):
			backWard(str);
			break;
		case(4):
			change(str);
			break;
		case(5):
			connect(s);
			break;
		}
	}
	public static void capital(String s){//小写转换为大写
		s=s.toUpperCase();//小写转换为大写
		System.out.println(s);
	}
	public static void minuscules(String s){//大写转换为小写
		s=s.toLowerCase();
		System.out.println(s);
	}
	public static void backWard(StringBuffer str){
		str.reverse();//翻转
		System.out.println(str);//输出逆序
	}
	public static void change(StringBuffer str){//大小写转换
		for(int i=0;i<str.length();i++){
			if(Character.isLowerCase(str.charAt(i))){//是否为小写字母
				str.setCharAt(i, Character.toUpperCase(str.charAt(i)));//转换为大写字母
			}else{
				str.setCharAt(i, Character.toLowerCase(str.charAt(i)));
			}
		}
		System.out.println(str);
	}
	public static void connect(String s){//最后一个
		s=s.toLowerCase();//全部化为小写
		StringBuffer st=new StringBuffer();
		for(int i=0;i<s.length();i++){
			if(i==0)//如果为0时
				st =st.append(s.charAt(0));
			else if(i !=s.length()-1){//如果i的不只为2个数字,或不为倒数第二个数
				if((int)s.charAt(i) !=(int)s.charAt(i-1)+1 || (int)s.charAt(i) != (int)s.charAt(i+1)-1){
					st =st.append(s.charAt(i));
				}else if(st.charAt(st.length()-1)!='-'){
					st =st.append('-');
				}
			}else
				st =st.append(s.charAt(i));
		}
		System.out.print(st);
	}
	
}

Published 146 original articles · won praise 3 · Views 2819

Guess you like

Origin blog.csdn.net/weixin_44522477/article/details/104492370