L1-023 输出GPLT(Java)

给定一个长度不超过10000的、仅由英文字母构成的字符串。请将字符重新调整顺序,按GPLTGPLT....这样的顺序输出,并忽略其它字符。当然,四种字符(不区分大小写)的个数不一定是一样多的,若某种字符已经输出完,则余下的字符仍按GPLT的顺序打印,直到所有字符都被输出。

输入格式:

输入在一行中给出一个长度不超过10000的、仅由英文字母构成的非空字符串。

输出格式:

在一行中按题目要求输出排序后的字符串。题目保证输出非空。

输入样例:

复制代码
pcTclnGloRgLrtLhgljkLhGFauPewSKgt

输出样例:

复制代码
GPLTGPLTGLTGLGLL

解题思路

  1. 字符统计 :由于我们只关心'G', 'P', 'L', 'T'这四个字符(不区分大小写),我们需要遍历输入字符串,并计算这四个字符各自出现的次数。这里,我们使用一个长度为4的整数数组count来分别存储'G', 'P', 'L', 'T'的计数。数组的索引0, 1, 2, 3分别对应这四个字符。
  2. 统一字符大小写:为了使程序能够处理大小写不一的输入,我们首先将整个输入字符串转换为大写(或小写)。这样,无论输入是大写还是小写,都可以统一处理。
  3. 遍历并计数 :对于字符串中的每一个字符,我们检查它是否是'G', 'P', 'L', 'T'中的一个。如果是,相应的计数器增加。这个过程可以通过switch语句实现。
  4. 按顺序输出:最后一步是根据GPLT的顺序输出字符。我们在一个循环中做这件事,每次循环都尝试按照GPLT的顺序输出一个字符。如果某个字符的计数器已经为0(意味着该字符已经全部输出),则跳过它。循环继续进行,直到所有字符的计数器都为0。
  5. 使用StringBuilder :在Java中,字符串是不可变的。因此,频繁的字符串连接操作(如在循环中添加字符)会产生很多临时对象,降低效率。为了提高效率,我们使用StringBuilder 来构建最终的字符串。StringBuilder允许我们在一个可变的字符序列中添加字符,从而减少不必要的对象创建。

解题过程中遇到的问题

  1. 如何让输出的字符按照GPLT的顺序
  2. 运行超时的问题

代码

java 复制代码
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Scanner;

public class Main {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        
        String str = br.readLine();
        int[] count = new int[4]; // 用于存储G, P, L, T的数量
        char[] chars = str.toUpperCase().toCharArray(); // 转换为大写,便于处理

        // 统计G, P, L, T的数量
        for (char c : chars) {
            switch (c) {
                case 'G': count[0]++; break;
                case 'P': count[1]++; break;
                case 'L': count[2]++; break;
                case 'T': count[3]++; break;
            }
        }

        StringBuilder sb = new StringBuilder();
        while (count[0] > 0 || count[1] > 0 || count[2] > 0 || count[3] > 0) {
            if (count[0]-- > 0) {
                sb.append('G');
            }
            if (count[1]-- > 0) {
                sb.append('P');
            }
            if (count[2]-- > 0) {
                sb.append('L');
            }
            if (count[3]-- > 0) {
                sb.append('T');
            }
        }

        System.out.println(sb);

    }


}
相关推荐
飛_36 分钟前
解决VSCode无法加载Json架构问题
java·服务器·前端
朝朝又沐沐3 小时前
算法竞赛阶段二-数据结构(36)数据结构双向链表模拟实现
开发语言·数据结构·c++·算法·链表
木棉软糖3 小时前
一个MySQL的数据表最多能够存多少的数据?
java
程序视点4 小时前
Java BigDecimal详解:小数精确计算、使用方法与常见问题解决方案
java·后端
愿你天黑有灯下雨有伞4 小时前
Spring Boot SSE实战:SseEmitter实现多客户端事件广播与心跳保活
java·spring boot·spring
薰衣草23334 小时前
一天两道力扣(6)
算法·leetcode
剪一朵云爱着4 小时前
力扣946. 验证栈序列
算法·
遇见尚硅谷4 小时前
C语言:*p++与p++有何区别
c语言·开发语言·笔记·学习·算法
Java初学者小白4 小时前
秋招Day20 - 微服务
java
天天开心(∩_∩)4 小时前
代码随想录算法训练营第三十二天
算法