• leetCode-Degree of an Array


    Description:
    Given a non-empty array of non-negative integers nums, the degree of this array is defined as the maximum frequency of any one of its elements.

    Your task is to find the smallest possible length of a (contiguous) subarray of nums, that has the same degree as nums.

    Example 1:

    Input: [1, 2, 2, 3, 1]
    Output: 2
    Explanation: 
    The input array has a degree of 2 because both elements 1 and 2 appear twice.
    Of the subarrays that have the same degree:
    [1, 2, 2, 3, 1], [1, 2, 2, 3], [2, 2, 3, 1], [1, 2, 2], [2, 2, 3], [2, 2]
    The shortest length is 2. So return 2.

    Example 2:

    Input: [1,2,2,3,1,4,2]
    Output: 6

    Note:

    nums.length will be between 1 and 50,000.
    nums[i] will be an integer between 0 and 49,999.

    My Solution:

    class Solution {
        public int findShortestSubArray(int[] nums) {
            Map<Integer,Integer>map = new HashMap<Integer,Integer>();
            int len = nums.length;
            for(int i = 0;i < len;i++){
                map.put(nums[i],(map.get(nums[i]) == null)?0:map.get(nums[i])+1);
            }
            int maxCount = 0;
            List<Integer>list = new ArrayList<Integer>();
            for(Integer key : map.keySet()){
                if(map.get(key) > maxCount){
                    maxCount = map.get(key);
                }
            }
            for(Integer key : map.keySet()){
                if(map.get(key) == maxCount){
                    list.add(key);
                }
            }
            List<Integer> temp = new ArrayList<Integer>();
            for(int i:nums){
                temp.add(Integer.valueOf(i));
            }
            int shortest = temp.lastIndexOf(list.get(0)) - temp.indexOf(list.get(0)) + 1;
            for(int i = 0;i < list.size();i++){
                int first = temp.indexOf(list.get(i));
                int last = temp.lastIndexOf(list.get(i));
                int length = last - first +1;
                if(length < shortest){
                    shortest = length;
                }
            }
            return shortest;
        }
    }
    Better Solution:
    class
    Solution { public int findShortestSubArray(int[] nums) { if (nums.length == 0 || nums == null) return 0; Map<Integer, int[]> map = new HashMap<>(); for (int i = 0; i < nums.length; i++){ if (!map.containsKey(nums[i])){ map.put(nums[i], new int[]{1, i, i}); // the first element in array is degree, second is first index of this key, third is last index of this key } else { int[] temp = map.get(nums[i]); temp[0]++; temp[2] = i; } } int degree = Integer.MIN_VALUE, res = Integer.MAX_VALUE; for (int[] value : map.values()){ if (value[0] > degree){ degree = value[0]; res = value[2] - value[1] + 1; } else if (value[0] == degree){ res = Math.min( value[2] - value[1] + 1, res); } } return res; } }
    Best Solution:
    
    class Solution {
        public int findShortestSubArray(int[] nums) {
            if (nums == null || nums.length == 0)
                return 0;
            int maxNum = 0;
            for (int n : nums){
                maxNum = Math.max(n, maxNum);
            }
            //由于数组的元素都为正整数,因此int[maxNum + 1]的下标可以包含数组中所有元素
            //start以nums的元素为下标,保存对应的起始点
            int[] start = new int[maxNum + 1];
            //end以nums的元素为下标,保存对应的终止点
            int[] end = new int[maxNum + 1];
            //que以nums的元素为下标,保存对应的次数
            int[] que = new int[maxNum + 1];
    
            for (int i = 0; i < nums.length; i++){
            //第一次出现nums[i]时,将i存入start,即起始点
                if (que[nums[i]] == 0)
                    start[nums[i]] = i;
                //每次出现同一个nums元素,更新end数组,即终止点
                end[nums[i]] = i;
                //每次出现同一个nums元素,更新que数组,计数
                que[nums[i]]++;
            }
    
            int max = 0;
            //找出最大degree
            for (int n : que)
                max = Math.max(max, n);
    
            List<Integer> maxNums = new ArrayList<>();
            #找出que中拥有最大计数的下标
            for (int i = 0; i < que.length; i++){
                if (que[i] == max)
                    maxNums.add(i);
            }
    
            int res = nums.length;
            #遍历maxNums,找出满足degree的最小子集长度
            for (int n : maxNums){
                int r = end[n] - start[n] + 1;
                res = Math.min(r, res);
            }
    
            return res;
        }
    版权声明:本文为博主原创文章,未经博主允许不得转载。
  • 相关阅读:
    图像轮廓最大内接矩形的求法
    python利用sift和surf进行图像配准
    Faster Rcnn随笔
    opencv利用svm训练
    灰度图片均衡化源码
    彩色直方图(源码)
    Tensorflow内存暴涨问题
    C++写入txt
    C++生成dll以及调用(函数)和类
    列表元素的几种统计方法总结(嵌套列表)
  • 原文地址:https://www.cnblogs.com/kevincong/p/7881387.html
Copyright © 2020-2023  润新知