有什么简单的方法来降序排序一个数组,就像他们有一个升序排序在数组类?
还是说我必须停止懒惰,自己做这件事:[
有什么简单的方法来降序排序一个数组,就像他们有一个升序排序在数组类?
还是说我必须停止懒惰,自己做这件事:[
当前回答
另一种使用Comparator的方法
import java.util.Arrays;
import java.util.Comparator;
...
Integer[] aInt = {6,2,3,4,1,5,7,8,9,10};
Arrays.sort(aInt, Comparator.reverseOrder() );
其他回答
另一种使用Comparator的方法
import java.util.Arrays;
import java.util.Comparator;
...
Integer[] aInt = {6,2,3,4,1,5,7,8,9,10};
Arrays.sort(aInt, Comparator.reverseOrder() );
另一种选择可能是(对于数字!!)
将数组乘以-1 排序 再乘以-1
从字面上说:
array = -Arrays.sort(-array)
您可以使用Comparator.reverseOrder()来使用流操作(Collections.stream())。
例如,假设你有这样一个集合:
List<String> items = new ArrayList<>();
items.add("item01");
items.add("item02");
items.add("item03");
items.add("item04");
items.add("item04");
你可以使用sorted()方法以“自然”的顺序打印项目(或者不用它,得到相同的结果):
items.stream()
.sorted()
.forEach(item -> System.out.println(item));
或者要按降序(倒序)打印它们,你可以使用带Comparator的sorted方法并颠倒顺序:
items.stream()
.sorted(Comparator.reverseOrder())
.forEach(item -> System.out.println(item));
注意,这要求集合已经实现Comparable(如Integer、String等)。
有一种方法可能会长一点,但它很有效。这是一个对int数组进行降序排序的方法。
希望有一天这能帮助到别人:
public static int[] sortArray (int[] array) {
int [] sortedArray = new int[array.length];
for (int i = 0; i < sortedArray.length; i++) {
sortedArray[i] = array[i];
}
boolean flag = true;
int temp;
while (flag) {
flag = false;
for (int i = 0; i < sortedArray.length - 1; i++) {
if(sortedArray[i] < sortedArray[i+1]) {
temp = sortedArray[i];
sortedArray[i] = sortedArray[i+1];
sortedArray[i+1] = temp;
flag = true;
}
}
}
return sortedArray;
}
对于列表
Collections.sort(list, Collections.reverseOrder());
对于数组
Arrays.sort(array, Collections.reverseOrder());