繁体   English   中英

在Java中使用Comparator对ArrayList进行排序

[英]Sorting of ArrayList using Comparator in Java

我在按升序对ArrayList进行排序时遇到问题。我在使用Comparator和Collat​​or of Collection类。如何实现预期的排序顺序? 非常感谢您的帮助。

通过算法计算的升序为:

[AutomationRejectNotification|,AutomationRejectNotification1011, AutomationRejectNotification1021,AutomationTestNotification1, AutomationTestNotification100,AutomationTestNotification2,testDisplay Template, Testing Chrome, Testing Field, Test Notfication, testnotif, Test Notification #1]

预期的升序排序顺序为:

[AutomationRejectNotification1011, AutomationRejectNotification1021, AutomationRejectNotification|,AutomationTestNotification1, AutomationTestNotification2,AutomationTestNotification100,Test Notfication, Test Notification #1, testDisplay Template, Testing Chrome, Testing Field, testnotif]

Java代码:

public static void listSort(List<String> o1, boolean order) {
        final Pattern p = Pattern.compile("^\\d+");
        Comparator<String> c = new Comparator<String>() {
            public int compare(String object1, String object2) {
                Collator collator = Collator.getInstance(Locale.US);
                Matcher m = p.matcher(object1);

                if (!m.find()) {
                    return collator.compare(object1, object2);
                } else {
                    Long number2 = null;
                    Long number1 = Long.parseLong(m.group());

                    m = p.matcher(object2);
                    if (!m.find()) {
                        return collator.compare(object1, object2);
                    } else {

                        number2 = Long.parseLong(m.group());

                        int comparison = number1.compareTo(number2);
                        if (comparison != 0) {
                            return comparison;
                        } else {
                            return collator.compare(object1, object2);
                        }
                    }
                }


            }
        };
        o1.sort(c);

您的Comparator器未正确实施Comparator界面的合同,因此所有押注均无效。 compare()方法必须具有所有这些属性:

sgn(compare(x, y)) == -sgn(compare(y, x))对于所有x和y。

((compare(x, y)>0) && (compare(y, z)>0))意味着compare(x, z)>0

compare(x, y)==0表示所有z的sgn(compare(x, z))==sgn(compare(y, z))

API文档

当两个比较的字符串都包含一个非空的十进制数字序列时,您按数字进行比较,而如果至少一个字符串没有任何数字,则可以通过整理程序进行比较。 产生以下结果:

compare("z1", "y") > 0

compare("y", "x3") > 0

compare("z1", "x3") < 0

,它不符合第二个必需属性(传递性)。

可能要做的是比较最长的前导无数字子字符串作为第一个条件,通过比较尾随数字(如果有的话)打破任何局限。 可能看起来像这样:

public static void listSort(List<String> o1, boolean order) {
    final Pattern p = Pattern.compile("([^0-9]*)([0-9]+)?");
    final Collator collator = Collator.getInstance(Locale.US);
    Comparator<String> c = new Comparator<String>() {
        public int compare(String object1, String object2) {
            Matcher m1 = p.matcher(object1);
            Matcher m2 = p.matcher(object2);

            if (!m1.lookingAt() || !m2.lookingAt()) {
                assert false : "Should never happen";
            }

            int result = collator.compare(m1.group(1), m2.group(1));

            if (result == 0) {
                String digits1 = m1.group(2);
                String digits2 = m2.group(2);

                if (digits1 != null && digits2 != null) {
                    Long number1 = Long.valueOf(digits1);
                    Long number2 = Long.valueOf(digits2);
                    result = number1.compareTo(number2);
                } else if (digits1 != null) {
                    result = 1;
                } else if (digits2 != null) {
                    result = -1;
                }
            }

            return result;
        }
    };
    o1.sort(c);
}

这将与您提出的预期顺序一致,但是还有其他排序方案也可以为那些特定元素产生相同的结果。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM