gpt4 book ai didi

java - 如何根据我们的要求对数组列表进行排序

转载 作者:行者123 更新时间:2023-12-01 11:42:29 26 4
gpt4 key购买 nike

包含数据的列表的顺序为

List<String> list = new ArrayList<String>(); 
list.add('R');
list.add('L');
list.add('H');
list.add('A');

如果我必须按 L、H、R、A 的顺序显示列表。

我尝试将每个列表值添加到 LinkedHashMap 中,并根据要求将所有列表值添加到另一个 Linked Hashmap 中。

还有其他最好的方法可以解决这个问题吗?

最佳答案

您可以使用 java.util.Collections.sort 方法,传递数组和比较器:

Collections.sort(list,new Comparator<String>(){

@Override
public int compare(String s1, String s2) {
// write your code to decide the order, return negative value for element that you want to appear before another element, zero for equality. same at compareTo works.
}

});

因此,如果您只想对 LRHA 字母进行排序,您可以执行以下操作(我假设任何其他字符串都将放置在末尾)

        List<String> list = new ArrayList<String>(); 
list.add('R');
list.add('L');
list.add('H');
list.add('A');

Collections.sort(list,new Comparator<String>(){

@Override
public int compare(String s1, String s2) {
if(s1 == null)
return 2;
if(s2 == null)
return -2;

if(s1.equals("L")) return -1;
if(s2.equals("L")) return 1;
if(s1.equals("H")) return -1;
if(s2.equals("H")) return 1;
if(s1.equals("R")) return -1;
if(s2.equals("R")) return 1;
if(s1.equals("A")) return -1;
if(s2.equals("A")) return 1;
return 2;
}

});

关于java - 如何根据我们的要求对数组列表进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29420255/

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