Leetcode每日一练--47

3346. 执行操作后元素的最高频率 I

难度:中等

提示

给你一个整数数组 nums 和两个整数 knumOperations

你必须对 nums 执行 操作 numOperations 次。每次操作中,你可以:

  • 选择一个下标 i ,它在之前的操作中 没有 被选择过。
  • nums[i] 增加范围 [-k, k] 中的一个整数。

在执行完所有操作以后,请你返回 nums 中出现 频率最高 元素的出现次数。

一个元素 x频率 指的是它在数组中出现的次数。

示例 1:

**输入:**nums = [1,4,5], k = 1, numOperations = 2

**输出:**2

解释:

通过以下操作得到最高频率 2 :

  • nums[1] 增加 0 ,nums 变为 [1, 4, 5]
  • nums[2] 增加 -1 ,nums 变为 [1, 4, 4]

示例 2:

**输入:**nums = [5,11,20,20], k = 5, numOperations = 1

**输出:**2

解释:

通过以下操作得到最高频率 2 :

  • nums[1] 增加 0 。

提示:

  • 1 <= nums.length <= 10^5
  • 1 <= nums[i] <= 10^5
  • 0 <= k <= 10^5
  • 0 <= numOperations <= nums.length

代码

cpp 复制代码
#include <stdlib.h>
#include <string.h>

int compare(const void *a, const void *b) {
    return (*(int *)a - *(int *)b);
}

int lower_bound(int *arr, int size, int target) {
    int left = 0, right = size;
    while (left < right) {
        int mid = left + (right - left) / 2;
        if (arr[mid] < target) left = mid + 1;
        else right = mid;
    }
    return left;
}

int upper_bound(int *arr, int size, int target) {
    int left = 0, right = size;
    while (left < right) {
        int mid = left + (right - left) / 2;
        if (arr[mid] <= target) left = mid + 1;
        else right = mid;
    }
    return left;
}

int maxFrequency(int* nums, int numsSize, int k, int numOperations) {
    if (numsSize == 0) return 0;
    
    // 排序原始数组
    int *sorted = (int *)malloc(numsSize * sizeof(int));
    memcpy(sorted, nums, numsSize * sizeof(int));
    qsort(sorted, numsSize, sizeof(int), compare);
    
    // 统计原始频率 (值域: 1~100000)
    int *freq = (int *)calloc(100001, sizeof(int));
    for (int i = 0; i < numsSize; i++) {
        if (nums[i] >= 1 && nums[i] <= 100000) freq[nums[i]]++;
    }
    
    // 生成候选值 v = {x, x-k, x+k}
    int *candidates = (int *)malloc(3 * numsSize * sizeof(int));
    int idx = 0;
    for (int i = 0; i < numsSize; i++) {
        candidates[idx++] = nums[i];
        candidates[idx++] = nums[i] - k;
        candidates[idx++] = nums[i] + k;
    }
    
    // 排序并去重候选值
    int totalCandidates = idx;
    qsort(candidates, totalCandidates, sizeof(int), compare);
    int uniqueCandidates = 0;
    for (int i = 0; i < totalCandidates; i++) {
        if (i == 0 || candidates[i] != candidates[i - 1]) {
            candidates[uniqueCandidates++] = candidates[i];
        }
    }
    
    int best = 0;
    for (int i = 0; i < uniqueCandidates; i++) {
        int v = candidates[i];
        int low = v - k;
        int high = v + k;
        
        // 计算区间 [v-k, v+k] 内的元素数量
        int left_idx = lower_bound(sorted, numsSize, low);
        int right_idx = upper_bound(sorted, numsSize, high);
        int C_v = right_idx - left_idx;
        
        int candidate;
        if (v >= 1 && v <= 100000 && freq[v] > 0) {
            candidate = (C_v < freq[v] + numOperations) ? C_v : (freq[v] + numOperations);
        } else {
            candidate = (C_v < numOperations) ? C_v : numOperations;
        }
        
        if (candidate > best) best = candidate;
    }
    
    free(sorted);
    free(freq);
    free(candidates);
    return best;
}
相关推荐
Fuxiao___40 分钟前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
Mr_Xuhhh1 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法
漫随流水1 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
穿条秋裤到处跑3 小时前
每日一道leetcode(2026.03.31):字典序最小的生成字符串
算法·leetcode
CoovallyAIHub5 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
Titan20245 小时前
map和set的封装学习笔记
数据结构·c++
CoovallyAIHub5 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
CoovallyAIHub5 小时前
IEEE Sensors | 湖南大学提出KGP-YOLO:先定位风电叶片再检测缺陷,三数据集mAP均超87%
算法
Yupureki5 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
副露のmagic6 小时前
数组章节 leetcode 思路&实现
算法·leetcode·职场和发展