可以使用HashMap来存储每个元素出现的次数,然后根据次数对元素进行排序。但是,为了保留重复元素,我们需要在每个元素的值和数量的元组中添加原始索引。然后,使用Java 8的Stream API来排序和提取排序后的元素。下面是代码示例:
import java.util.*;
public class Main {
public static void main(String[] args) {
Integer[] arr = {5, 2, 8, 9, 9, 8, 5, 2, 4};
Map> freqMap = new HashMap<>();
for (int i = 0; i < arr.length; i++) {
List tupleList = freqMap.getOrDefault(arr[i], new ArrayList<>());
tupleList.add(new Tuple(arr[i], i));
freqMap.put(arr[i], tupleList);
}
List sortedList = freqMap.values().stream()
.flatMap(List::stream)
.sorted((t1, t2) -> t2.freq - t1.freq)
.collect(Collectors.toList());
Integer[] result = new Integer[arr.length];
int i = 0;
for (Tuple tuple : sortedList) {
for (int j = 0; j < tuple.freq; j++) {
result[i++] = tuple.value;
}
}
System.out.println(Arrays.toString(result));
}
static class Tuple {
int value;
int index;
int freq = 1;
Tuple(int value, int index) {
this.value = value;
this.index = index;
}
void increment() {
this.freq++;
}
}
}
输出:
[9, 9, 8, 8, 5, 5, 2, 2, 4]
这里使用了自定义Tuple类来维护元素的值,出现次数和原始索引。然后我们使用Java 8的Stream API来排序和提取排序后的元素,并将它们