LeetCode 1224. 最大相等频率(哈希)
生活随笔
收集整理的這篇文章主要介紹了
LeetCode 1224. 最大相等频率(哈希)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- 1. 題目
- 2. 解題
1. 題目
給出一個正整數數組 nums,請你幫忙從該數組中找出能滿足下面要求的 最長 前綴,并返回其長度:
- 從前綴中 刪除一個 元素后,使得所剩下的每個數字的出現次數相同。
如果刪除這個元素后沒有剩余元素存在,仍可認為每個數字都具有相同的出現次數(也就是 0 次)。
示例 1: 輸入:nums = [2,2,1,1,5,3,3,5] 輸出:7 解釋:對于長度為 7 的子數組 [2,2,1,1,5,3,3], 如果我們從中刪去 nums[4]=5, 就可以得到 [2,2,1,1,3,3],里面每個數字都出現了兩次。示例 2: 輸入:nums = [1,1,1,2,2,2,3,3,3,4,4,4,5] 輸出:13示例 3: 輸入:nums = [1,1,1,2,2,2] 輸出:5示例 4: 輸入:nums = [10,2,8,9,3,8,1,5,2,3,7,6] 輸出:8提示: 2 <= nums.length <= 10^5 1 <= nums[i] <= 10^5來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/maximum-equal-frequency
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。
2. 解題
class Solution { public:int maxEqualFreq(vector<int>& nums) {unordered_map<int,int> m;//數字,數字的個數freqmap<int,int> size_count;//數字的個數freq,freq的頻數int maxlen = 1, MINf, MAXf;for(int i = 0; i < nums.size(); ++i) {m[nums[i]]++;size_count[m[nums[i]]]++;if(--size_count[m[nums[i]]-1] <= 0)size_count.erase(m[nums[i]]-1);MINf = size_count.begin()->first;MAXf = size_count.rbegin()->first;// 1, [1,2,3,4,5] size_count[1] = 5// 2, [2,2,2,2] size_count[4] = 1// 3, [2,2,1,1,0,0,3,3,3] size_count[2] = 3, size_count[3] = 1// 4, [1,2,2,2,3,3,3] size_count[1] = 1, size_count[3] = 2// 這4種情況才可以if((size_count.size()==1 && (MINf==1 || size_count[MINf]==1))||(size_count.size()==2 && ((size_count[MAXf]==1 && MAXf-MINf==1) || (size_count[MINf]==1 && MINf==1))))maxlen = i+1;}return maxlen;} };604 ms 68.6 MB C++
我的CSDN博客地址 https://michael.blog.csdn.net/
長按或掃碼關注我的公眾號(Michael阿明),一起加油、一起學習進步!
總結
以上是生活随笔為你收集整理的LeetCode 1224. 最大相等频率(哈希)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 特征处理
- 下一篇: LeetCode 809. 情感丰富的文