1108 String复读机(JAVA)

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

输入格式:

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

输出格式:

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

样例:">输入样例:

sTRidlinSayBingStrropriiSHSiRiagIgtSSr

输出样例:

StringStringSrigSriSiSii

代码实现:

import java.io.*;

/**
 * @author yx
 * @date 2022-07-28 23:13
 */
public class Main {
    static PrintWriter out=new PrintWriter(System.out);
    static BufferedReader ins=new BufferedReader(new InputStreamReader(System.in));
    static StreamTokenizer in=new StreamTokenizer(ins);

    public static void main(String[] args) throws IOException {
        int S=0;
        int t=0;
        int r=0;
        int i=0;
        int n=0;
        int g=0;
        String[] split=ins.readLine().split("");
        for (int j = 0; j < split.length; j++) {
            if(split[j].equals("S")){
                S++;
            }
            if(split[j].equals("t")){
                t++;
            }if(split[j].equals("r")){
                r++;
            }if(split[j].equals("i")){
                i++;
            }if(split[j].equals("n")){
                n++;
            }
            if(split[j].equals("g")){
                g++;
            }
        }
        while (true){
            if(S!=0||t!=0||r!=0||i!=0||n!=0||g!=0){
                if(S!=0){
                    System.out.print("S");
                    S--;
                }
                if(t!=0){
                    System.out.print("t");
                    t--;
                }
                if(r!=0){
                    System.out.print("r");
                    r--;
                }
                if(i!=0){
                    System.out.print("i");
                    i--;
                }
                if(n!=0){
                    System.out.print("n");
                    n--;
                }
                if(g!=0){
                    System.out.print("g");
                    g--;
                }
            }else {
                break;
            }
        }
    }
}

1108 String复读机(JAVA)_第1张图片

 

你可能感兴趣的:(PAT乙(JAVA题解),java,数据结构,开发语言)