Java语言高分悬赏:将一个数组的偶数位的元素按照升序排序,奇数位的元素按照绝对值排序
public class Demo01 {
public static void main(String[] args) {
Integer[] arrays = {-8, 3, 5, 1, -9, 10, -30, 18, 2, -6};//初始化一个数组
List<Integer> evenList = new ArrayList<>();//偶数列表
List<Integer> oddList = new ArrayList<>();//奇数列表
for (int i = 0; i < arrays.length; i++) {
if (i % 2 == 0) {//奇数位 这里我把arrays[0]理解为第1个数位,即奇数位
oddList.add(arrays[i]);
} else {//偶数位
evenList.add(arrays[i]);
}
}
//将一个数组的偶数位的元素按照升序排序,奇数位的元素按照绝对值排序
List<Integer> resultEvenList = new ArrayList<>();//偶数列表
List<Integer> resultOddList = new ArrayList<>();//奇数列表
resultEvenList = evenList.stream()
.sorted()
.collect(Collectors.toList());
resultOddList = oddList.stream()
.sorted(Comparator.comparing(Math::abs))
.collect(Collectors.toList());
Integer[] resultArrays = new Integer[arrays.length];
//将排好序的值保存到一个新的数组
for (int i = 0; i < arrays.length; i++) {
if (i % 2 == 0) {//奇数位
resultArrays[i] = resultOddList.get(i / 2);
} else {//偶数位
resultArrays[i] = resultEvenList.get((i - 1) / 2);
}
}
System.out.println(Arrays.asList(resultArrays).toString());
}
}
打印结果