以下是一个示例代码,用于按特定顺序对数组进行排序:
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数字数组