字符串排序-newcoder

题目描述

编写一个程序,将输入字符串中的字符按如下规则排序。

规则 1 :英文字母从 A 到 Z 排列,不区分大小写。

如,输入: Type 输出: epTy

规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。

如,输入: BabA 输出: aABb

规则 3 :非英文字母的其它字符保持原来的位置。
 

如,输入: By?e 输出: Be?y

Solution: 用ABCDE。。。。去排位

public class Main {

    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);

        while (sc.hasNextLine()) {

            String str = sc.nextLine();

            char[] chs = str.toCharArray();

            StringBuffer sb = new StringBuffer();
            for (int i = 0; i < 26; i++) {
                char c = (char) (i + 'A');

                for (int j = 0; j < str.length(); j++) {

                    if (chs[j] == c || chs[j] == (char) (c + 32)) {
                        sb.append(chs[j]);
                    }
                }

            }

            for (int k = 0; k < str.length(); k++) {
                if (!(chs[k] >= 'A' && chs[k] <= 'Z'

                        || chs[k] >= 'a' && chs[k] <= 'z')) {
                    sb.insert(k, chs[k]);
                }

            }

            System.out.println(sb.toString());

        }

    }
}
发布了595 篇原创文章 · 获赞 11 · 访问量 10万+

猜你喜欢

转载自blog.csdn.net/xiamaocheng/article/details/104701088