陈正磊


私信TA

用户名:RossTran

访问量:14973

签 名:

晨兴理荒秽,带月荷锄归。

等  级
排  名 178
经  验 6828
参赛次数 15
文章发表 34
年  龄 0
在职情况 学生
学  校 湖北生物科技职业学院
专  业

  自我简介:

解题思路:



注意事项:



参考代码:

import java.util.Scanner;


public class 简单的字符串 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();
		String []result=new String[n];
		for (int i = 0; i < n; i++) {
			String str=sc.next();
			String tempStr="";
			int k=1;
			if (str.length()==1) {//特殊情况,字符串只有一个
				tempStr=str;
			}
			for (int j = 0; j < str.length()-1; j++) {
				if (str.charAt(j)==str.charAt(j+1)) {
					k++;
					if (j==str.length()-2) {//特殊情况,字符串以相同的字符结尾
						String kStr= k==1?"":(k+"");
						tempStr+=(kStr+str.charAt(j));
					}
				}else {
					String kStr= k==1?"":(k+"");
					tempStr+=(kStr+str.charAt(j));
					k=1;
				}
			}
			//判断最后一个字符
			if (str.length()>1 && str.charAt(str.length()-1)!=str.charAt(str.length()-2)) {
				tempStr+=str.charAt(str.length()-1);
			}
			//存储结果
			result[i]=tempStr;
		}
		for (String string : result) {
			System.out.println(string);
		}
	}

}

在看了宇月幸成  的题解后,修改优化

import java.util.Scanner;


public class 简单的字符串 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();
		String []result=new String[n];
		for (int i = 0; i < n; i++) {
			String str=sc.next();
			str+="*";//添加一个无关的字符
			String tempStr="";
			int k=1;
			if (str.length()==1) {//特殊情况,字符串只有一个
				tempStr=str;
			}
			for (int j = 0; j < str.length()-1; j++) {
				if (str.charAt(j)==str.charAt(j+1)) {
					k++;
				}else {
					String kStr= k==1?"":(k+"");
					tempStr+=(kStr+str.charAt(j));
					k=1;
				}
			}
			//存储结果
			result[i]=tempStr;
		}
		for (String string : result) {
			System.out.println(string);
		}
	}

}



 

0.0分

2 人评分

  评论区

可以用StringBuffer或者StringBuilder
2022-02-08 20:54:33
  • «
  • 1
  • »