以下是一个示例代码,用于按特定顺序对数组进行排序:
import java.util.Arrays;
import java.util.Comparator;
public class SortArrayInSpecificOrder {
public static void main(String[] args) {
int[] arr = {3, 1, 4, 2, 5};
int[] order = {2, 1, 3, 5, 4};
sortArrayInSpecificOrder(arr, order);
System.out.println(Arrays.toString(arr));
}
public static void sortArrayInSpecificOrder(int[] arr, int[] order) {
Integer[] arrWrapper = new Integer[arr.length];
for (int i = 0; i < arr.length; i++) {
arrWrapper[i] = arr[i];
}
Arrays.sort(arrWrapper, Comparator.comparingInt(a -> {
int index = -1;
for (int i = 0; i < order.length; i++) {
if (order[i] == a) {
index = i;
break;
}
}
return index;
}));
for (int i = 0; i < arr.length; i++) {
arr[i] = arrWrapper[i];
}
}
}
在这个示例中,输入的数组 arr 是要排序的数组,order 是按照哪个顺序进行排序的数组。我们使用了 Arrays.sort() 方法来对 arr 数组进行排序,通过传入一个自定义的 Comparator 实现对数组元素的比较。
在自定义的 Comparator 中,我们首先将 arr 转换为一个包装类数组 arrWrapper,这样可以使用 Comparator 的泛型方法。然后,我们使用 Comparator.comparingInt() 方法来定义一个比较器,该比较器会根据 order 数组中元素的顺序进行排序。具体实现中,我们遍历 order 数组,找到 arrWrapper 中每个元素在 order 数组中的索引,然后将这个索引作为比较值返回。
最后,我们将排好序的 arrWrapper 数组中的元素重新赋值给原始的 arr 数组。输出结果为 [2, 1, 3, 4, 5],符合按特定顺序排序的要求。
上一篇:按特定顺序排序列名
下一篇:按特定顺序排序一个JS数字数组