数组的相对排序--java

给你两个数组,arr1 和 arr2,

arr2 中的元素各不相同
arr2 中的每个元素都出现在 arr1 中
对 arr1 中的元素进行排序,使 arr1 中项的相对顺序和 arr2 中的相对顺序相同。未在 arr2 中出现过的元素需要按照升序放在 arr1 的末尾。

示例:

输入:arr1 = [2,3,1,3,2,4,6,7,9,2,19], arr2 = [2,1,4,3,9,6]
输出:[2,2,2,1,4,3,3,9,6,7,19]

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/relative-sort-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
   public int[] relativeSortArray(int[] arr1, int[] arr2) {
       //利用计数排序的思维,下标当作元素值,元素内容当作出现频率
        int[] bucket = new int[1001];   //新建最大数组
        for (int i = 0; i < arr1.length; i++)   //遍历arr1数组
            //首先arr1[i]=2,那么找到bucket[2]下标的元素,让元素内容+1,代表2出现的次数
            bucket[arr1[i]]++;  //统计arr1中元素出现的频率
        
        int idx = 0;    //重写arr1数组的下标
        for (int i = 0; i < arr2.length; i++)   //遍历arr2数组
            while (bucket[arr2[i]] > 0) {   //使用arr2中的元素去遍历bucket数组中元素,出现的次数大于0时
                bucket[arr2[i]]--;      //出现次数减1
                arr1[idx] = arr2[i];  //按顺序把arr2中的元素放入arr1数组中
                idx++;
            }
        
        for (int i = 0; i < bucket.length; i++) //遍历bucket数组
            while (bucket[i] > 0) { //循环找到出现次数大于0的元素
                bucket[i]--;    //出现次数-1
                arr1[idx] = i;  //把i代表元素值给arr1数组
                idx++;          
            }
        
        return arr1;
    }
}
posted @ 2021-10-27 21:27  网抑云黑胶SVIP用户  阅读(87)  评论(0编辑  收藏  举报