最大相等频率Java
文章发布较早,内容可能过时,阅读注意甄别。
# 题目
给你一个正整数数组 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
提示:
- 2 <= nums.length <= 105
- 1 <= nums[i] <= 105
# 思路
三种更新最长前缀的情况
# 解法
class Solution {
final int N = 100010;
public int maxEqualFreq(int[] nums) {
int[] cnt = new int[N], sum = new int[N];
int max = 0, ans = 0;
for (int i = 0; i < nums.length; i++) {
sum[cnt[nums[i]]++]--;
sum[cnt[nums[i]]]++;
max = Math.max(cnt[nums[i]], max);
// 三种更新最长前缀的情况
// 1. 最大出现次数为 1
if (max == 1) ans = i + 1;
// 2. 除了一个数字出现一次,剩下数字均出现 max 次
if (max * sum[max] + 1 == i + 1) ans = i + 1;
// 3. 除了一个数字出现 max 次,剩下数字均出现 max - 1 次
if ((max - 1) * sum[max - 1] + max == i + 1) ans = i + 1;
}
return ans;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# 总结
- 分析出几种情况,然后分别对各个情况实现