题解 | #字符串排序#

字符串排序

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

import java.util.Scanner;
import java.lang.StringBuilder;

// 其实该题就考排序,1.其他字符干扰 ,2.大小写不区分判断
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNext()) { // 注意 while 处理多个 case
            String a = in.nextLine();
            System.out.println(getSortStr(a));
        }
    }
    private static String getSortStr(String s) {
        //先把不是字母的全去掉
        StringBuilder sb1 = new StringBuilder();
        char [] arr1 = s.toCharArray();
        for (char c : arr1) {
            if (Character.isLetter(c)) {
                sb1.append(c);
            }
        }
        //然后对字母进行冒泡排序,排序忽略大小写
        char[] arr2 = sb1.toString().toCharArray();
        char temp = 'Z';
        for (int i = 0; i < arr2.length; i++) {
            for (int j = 0; j < arr2.length - i - 1; j++) {
                if (Character.isLetter(arr2[j])) {
                    char up_c1 = Character.toUpperCase(arr2[j]);
                    char up_c2 = Character.toUpperCase(arr2[j + 1]);
                    if (up_c1 - up_c2 > 0) {
                        temp = arr2[j];
                        arr2[j] = arr2[j + 1];
                        arr2[j + 1] = temp;
                    }
                }
            }
        }
        //组装,把非字母的给他还原到原来的位置,如果是字母则按照冒牌排序后的结果给他输出
        StringBuilder sb2 = new StringBuilder();
        for (int i = 0, j = 0; i < s.length(); i++) {
            if (Character.isLetter(arr1[i])) {
                //是字母的话,在冒泡排序好的里面取一个
                sb2.append(arr2[j]);
                j++;
            } else {
                //不是字母的话,就直接把改字符放进去
                sb2.append(arr1[i]);
            }
        }
        return sb2.toString();
    }
}

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-15 17:32
点赞 评论 收藏
分享
06-10 21:15
门头沟学院 Java
宁阿:好多这种没🧠的公司,他们估计都不知道毕业的人不能给安排实习岗
实习吐槽大会
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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