题解 | #字符串排序#

字符串排序

https://www.nowcoder.com/practice/5190a1db6f4f4ddb92fd9c365c944584

没想到用同一大小写的方式来排序,但是想到了另一个方式来做
import java.io.IOException;
import java.util.*;

public class Main {
    public static void main(String[] args) throws IOException {
        Scanner scanner = new Scanner(System.in);
        String line = scanner.nextLine();
        char[] chars = line.toCharArray();
        Set<Integer> notWordIndex = new HashSet<>();
        String[] strs = new String[26];
        for (int i = 0; i < chars.length; i++) {
            char c = chars[i];
            if ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z')) {
                int index = (c >= 'a' && c <= 'z') ? c - 'a' : c - 'A';
                String s = strs[index];
                if (s == null) {
                    strs[index] = c + "";
                } else {
                    strs[index] = s + c;
                }
            } else {
                notWordIndex.add(i);
            }
        }

        List<Character> letterList = new ArrayList<>();
        for (String s : strs) {
            if (s != null) {
                for (char c : s.toCharArray()) {
                    letterList.add(c);
                }
            }
        }
        StringBuilder result = new StringBuilder();
        for (int i = 0, j = 0; i < chars.length; i++) {
            if (notWordIndex.contains(i)) {
                result.append(chars[i]);
            } else {
                result.append(letterList.get(j++));
            }
        }
        System.out.println(result);
    }
}




全部评论

相关推荐

白火同学:1、简历可以浓缩成一页,简历简历先要“简”方便HR快速过滤出有效信息,再要“历”用有效信息突出个人的含金量。 2、教育背景少了入学时间~毕业时间,HR判断不出你是否为应届生。 3、如果你的平台账号效果还不错,可以把账号超链接或者用户名贴到对应位置,一是方便HR知道你是具体做了什么内容的运营,看到账号一目了然,二是口说无凭,账号为证,这更有说服力。
面试被问期望薪资时该如何...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务