题目
一个数组,其数据范围在0~200之间,将其从小到大排序
解析
给定一个数组;
首先获取去最大值,然后创建一个长度为这个最大值+1的临时数组;
遍历原数组,如果原数组中的元素是n,在临时数组索引为n的位置加1;
临时数组为:
把元素的索引作为值,元素作为值的个数复制到原数组;
代码
public static void countSort(int[] arr) {
if (arr == null || arr.length < 2) {
return;
}
int max = Integer.MIN_VALUE;
for (int i = 0; i < arr.length; i++) {
max = Math.max(max, arr[i]);
}
int[] bucket = new int[max + 1];
for (int i = 0; i < arr.length; i++) {
bucket[arr[i]]++;
}
int i = 0;
for (int j = 0; j < bucket.length; j++) {
while (bucket[j]-- > 0) {
arr[i++] = j;
}
}
}