liuxuquan


私信TA

用户名:Qone

访问量:2223

签 名:

等  级
排  名 2188
经  验 2345
参赛次数 3
文章发表 2
年  龄 0
在职情况 在职
学  校
专  业

  自我简介:

import java.util.Scanner;

public class Main {
    /**
     * ABBCCC
     * j
     *  k
     * 长度为k-j,字符取的是j位置的字符
     */
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            int time = scanner.nextInt();
            for (int i = 0; i < time; i++) {
                char[] chars = scanner.next().toCharArray();
                //避免每次都要在循环里面获取长度
                int len = chars.length;
                StringBuilder resultBuilder = new StringBuilder();
                //j和k双指针,当j和k的值不同时,记录数值(k-j)即为相同字符的长度,并将j瞬间移动到k的地方,k继续向下便利
                int j = 0, k = 0;
                for (k = j + 1; k < len; k++) {
                    if (chars[j] != chars[k]) {
                        if (k - j > 1) {
                            resultBuilder.append(k - j);
                        }
                        resultBuilder.append(chars[j]);
                        j = k;
                    }
                }
                //处理最后的场景
                if (k - j > 1) {
                    resultBuilder.append(k - j);
                }
                resultBuilder.append(chars[j]);
                System.out.println(resultBuilder.toString());
            }
        }
    }
}

//   java相关技术文章,希望帮助到你


 

0.0分

1 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区