1 回答
TA贡献1875条经验 获得超5个赞
您可以使用 Comparator 链。
List<String> fruits = new ArrayList<>(Arrays.asList(
"Apple", "Banana", "Orange", "Watermelon", "Peach"));
fruits.sort(Comparator.comparing((String s) -> !s.contains("O") && !s.contains("o"))
.thenComparing(Comparator.naturalOrder()));
System.out.println(fruits.stream().collect(Collectors.joining(", ")));
第一个比较器查看字符串是否包含 O 使那些先行,第二个比较器使用自然顺序。
注意:Boolean.TRUE.compareTo(Boolean.FALSE) > 0为了让包含 O 的字符串先走,我用一个!
这打印
Orange, Watermelon, Apple, Banana, Peach
注意:在这种情况下,new ArrayList<>( ... )不需要,因为sort不会改变元素的数量,只是重新排列它们。
编辑:基于@Holger 的建议。
如果首选稳定排序,即尽可能保持顺序不变。
List<String> fruits = Arrays.asList(
"Watermelon", "Peach", "Orange", "Banana", "Apple");
fruits.sort(Comparator.comparing((String s) -> !s.contains("O") && !s.contains("o")));
System.out.println(fruits.stream().collect(Collectors.joining(", ")));
印刷
Watermelon, Orange, Peach, Banana, Apple
添加回答
举报