zoukankan      html  css  js  c++  java
  • Java字符串06-字符串排序

    package doudou;
    
    import java.util.Arrays;
    import java.util.Comparator;
    
    public class test_stringSort {
        public static void main(String[] args) {
            String a = "11,44,22,3,321,55,33,0";
            String[] b = a.split(",");
            Arrays.sort(b, new Comparator<String>() {
                public int compare(String o1, String o2) {
                    return Integer.parseInt(o1) > Integer.parseInt(o2) ? -1
                            : Integer.parseInt(o1) < Integer.parseInt(o2) ? 1 : 0;
                }
            });
            System.out.println(Arrays.toString(b));
            System.out.println(b.getClass());
            String replace = Arrays.toString(b).replaceAll("[\[\]]", """);
            System.out.println(replace);
            System.out.println(replace.getClass());
        }
    
    }

    运行结果:

    [321, 55, 44, 33, 22, 11, 3, 0]
    class [Ljava.lang.String;
    "321, 55, 44, 33, 22, 11, 3, 0"
    class java.lang.String

    请注意:  

    Arrays.sort 排序有坑 如下图,要排序的话,还是指定排序规则吧!
    Array的sort()方法默认把所有元素先转换为String再排序,
    '
    321'排在了'33'的前面:第一位相同,则比较第二位,因为第二位字符'2'比字符'3'的ASCII码小,所以321 排在33前面
     
  • 相关阅读:
    8组-Alpha冲刺-2/6
    8组-Alpha冲刺-1/6
    8组 需求分析报告
    结对编程作业
    8组 团队展示
    第一次个人编程作业
    第一次博客作业
    面向对象程序设计寒假作业3
    面向对象程序设计寒假作业2
    面向对象程序设计寒假作业1
  • 原文地址:https://www.cnblogs.com/eosclover/p/13499755.html
Copyright © 2011-2022 走看看