gpt4 book ai didi

java - 使用一些规则对文本进行排序

转载 作者:行者123 更新时间:2023-12-03 02:32:40 27 4
gpt4 key购买 nike

我有一个数组列表,如下

100 AAA 500-1 Lorem Ipsum
100 BBB 500-2 Lorem Ipsum
101 AAA 500-1 Lorem Ipsum
101 AAA 500-2 Lorem Ipsum
100 BBB 500-3 Lorem Ipsum

我希望将其排序为

101 AAA 500-1 Lorem Ipsum
101 AAA 500-2 Lorem Ipsum
100 AAA 500-1 Lorem Ipsum
100 BBB 500-2 Lorem Ipsum
100 BBB 500-3 Lorem Ipsum

首先,按数字降序 (101, 100)。

第二,按三个字母单词升序(AAA、BBB)。

第三,按第三列升序(500-1, 500-2, 500-3)

我可以按空格分割每个元素并获取单个单词并进行排序。但是有人可以用其他方式或已知算法帮助我吗?如果您需要更多信息,请告诉我。

提前谢谢您。

最佳答案

创建 Comparator会解决你的问题。你应该实现这样的东西:

public class MyComparator implements Comparator<MyObject> {    
public int compare(MyObject o1, MyObject o2) {
if (o1 == null || o2 == null) {
throw new NullPointerException();
}
if (o1.getValue1() != o2.getValue1()) {
return Integer.compare(o1.getValue1(), o2.getValue1());
}
return Integer.compare(o1.getValue2(), o2.getValue2());
}
}

当然还有更多方法可以解决这个问题,例如,您可以实现自己的排序算法。但是,我认为使用 Comparator 是解决该问题的正确“java-way”。

关于java - 使用一些规则对文本进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16358894/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com