JavaInterview JavaInterview
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)

『Java面试+Java学习』
首页
指南
分类
标签
归档
  • CSDN (opens new window)
  • 文档集合 (opens new window)
  • 系统架构 (opens new window)
  • 微信号 (opens new window)
  • 公众号 (opens new window)
  • 指南
  • 简历

  • Java

  • 面试

  • 算法

  • algorithm
  • leetcode
JavaInterview.cn
2024-09-22
目录

最大相等频率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

# 总结

  • 分析出几种情况,然后分别对各个情况实现
微信 支付宝
#Java
最近更新
01
1686. 石子游戏VI Java
08-18
02
1688. 比赛中的配对次数 Java
08-18
03
1687. 从仓库到码头运输箱子 Java
08-18
更多文章>
Theme by Vdoing | Copyright © 2019-2025 JavaInterview.cn
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式