首页 > 编程语言 > 详细

Java字符串06-字符串排序

时间:2020-08-16 17:45:53      阅读:70      评论:0      收藏:0      [点我收藏+]

 

 

 

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前面
技术分享图片

 

 

 

 

Java字符串06-字符串排序

原文:https://www.cnblogs.com/eosclover/p/13499755.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!