码迷,mamicode.com
首页 > 其他好文 > 详细

[leetcode]Array-697. Degree of an Array

时间:2018-01-13 21:03:19      阅读:167      评论:0      收藏:0      [点我收藏+]

标签:color   sam   tin   example   int   span   ++   blog   empty   

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
class Solution {  
 2 public:  
 3     int findShortestSubArray(vector<int>& nums) {  
 4         int len = nums.size() ;  
 5         if (len < 2)  
 6             return len ;  
 7         int Max = 0 ;  
 8         unordered_map<int,int> startIndex , count ;  
 9         int res = len ;  
10         for(int i = 0 ; i < len ; i++){  
11             if (startIndex.count(nums[i]) == 0)  
12                 startIndex[nums[i]] = i ;  
13             count[nums[i]]++ ;  
14             if (count[nums[i]] > Max){  
15                 res = i - startIndex[nums[i]] + 1 ;  
16                 Max = count[nums[i]] ;  
17             }  
18             if (count[nums[i]] == Max){  
19                 res = min(i - startIndex[nums[i]] + 1 , res) ;    
20             }  
21         }  
22         return res ;  
23     }  
24 };  

 

[leetcode]Array-697. Degree of an Array

标签:color   sam   tin   example   int   span   ++   blog   empty   

原文地址:https://www.cnblogs.com/chenhan05/p/8280177.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!