zoukankan      html  css  js  c++  java
  • LeetCode 697. 数组的度

    https://leetcode-cn.com/problems/degree-of-an-array/

    这个题跟昨天做的子串很相似哈,哈希表+滑动窗口完成。

    class Solution {
        public int findShortestSubArray(int[] nums) {
           HashMap<Integer, Integer> map = new HashMap<>();
            int max = Integer.MIN_VALUE;
            for (int num : nums) {
                map.put(num, map.getOrDefault(num, 0) + 1);
                max = Math.max(max,map.get(num));
            }
            HashMap<Integer,Integer> cur = new HashMap<>();
            int fast = 0;
            int slow = 0;
            int min = Integer.MAX_VALUE;
            while(fast < nums.length){
                cur.put(nums[fast],cur.getOrDefault(nums[fast],0)+1);
                while(cur.get(nums[fast]).equals(max)){
                    min = Math.min(min,fast - slow + 1);
                    cur.put(nums[slow],cur.get(nums[slow])-1);
                    slow++;
                }
                fast++;
            }
            return min;
        }
    }

    思路就是先把原来的数组的度找出来,就是出现最多的元素的次数,然后就进入滑动窗口,快指针一直访问到当前度数与原数组的度相等,就开始缩小左边界,直到度不再满足条件,这个做出来要29ms,只击败了50%的人。

    后来看了看题目给的条件,数组长度最长是已知的,那么我们就不需要去用map统计长度了,直接开数组就完事。

    class Solution {
        public int findShortestSubArray(int[] nums) {
            int[] count = new int[50000];
            int max = Integer.MIN_VALUE;
            for (int num : nums) {
                count[num]++;
                max = Math.max(max,count[num]);
            }
            HashMap<Integer,Integer> cur = new HashMap<>();
            int fast = 0;
            int slow = 0;
            int min = Integer.MAX_VALUE;
            while(fast < nums.length){
                cur.put(nums[fast],cur.getOrDefault(nums[fast],0)+1);
                while(cur.get(nums[fast]).equals(max)){
                    min = Math.min(min,fast - slow + 1);
                    cur.put(nums[slow],cur.get(nums[slow])-1);
                    slow++;
                }
                fast++;
            }
            return min;
        }
    }

    这次做完只需要19ms,击败87%的人

  • 相关阅读:
    大数据时代的艺术金融
    与“数”同行:大数据驱动大学变革
    与“数”同行:大数据驱动大学变革
    财务信息化:大数据小时代
    财务信息化:大数据小时代
    Python导出DBF文件到Excel的方法
    Python导出DBF文件到Excel的方法
    SolrJ的入门
    Spring Data Solr入门
    使用solr进行配置文件
  • 原文地址:https://www.cnblogs.com/ZJPaang/p/12950268.html
Copyright © 2011-2022 走看看