蓝桥杯每日真题 - 第10天

题目:(班级活动)

题目描述(14届 C&C++ B组C题)

解题思路:

题目要求我们找到最小的修改次数,使得任意一名同学的 ID 都与另一名同学的 ID 不相同。可以总结出这是一个寻找"重复数字最少修改次数"的问题。我们可以按照以下思路来解决:

  1. 统计频次:遍历学生的 ID 列表,统计每个 ID 出现的次数。

  2. 处理重复 ID:对于每一个出现次数超过 1 的 ID,需要将多余的 ID 修改为未出现的 ID。

  3. 贪心选择未使用的 ID :我们可以将重复的 ID 替换为一个在 [1, n] 范围内未使用的 ID。

代码实现(C语言):

cs 复制代码
#include <stdio.h>

int main() {
    int n;
    scanf("%d", &n);
    int ids[n];
    int count[100001] = {0};  // 假设每个 id 范围在 [1, 100000],足够存储频次
    
    // 读取输入并统计频次
    for (int i = 0; i < n; i++) {
        scanf("%d", &ids[i]);
        count[ids[i]]++;
    }

    int modifications = 0;
    int nextAvailableId = 1;

    for (int i = 0; i < n; i++) {
        while (count[ids[i]] > 1) {  // 当前 id 有重复
            // 找到一个未被使用的 id
            while (nextAvailableId <= n && count[nextAvailableId] > 0) {
                nextAvailableId++;
            }

            // 替换重复 id,并更新计数
            count[ids[i]]--;
            count[nextAvailableId]++;
            modifications++;
        }
    }

    printf("%d\n", modifications);
    return 0;
}
复制代码
 ​​​​

代码分析:

  • 统计频次 :使用 count 数组记录每个 ID 的出现次数,遍历时将重复的 ID 进行计数。

  • 贪心选择未使用的 ID :设置 nextAvailableId,每当遇到重复 ID 时,找到下一个未使用的 ID 并进行替换。

  • 计数修改次数 :每次替换重复 ID 后,增加 modifications 的计数。

得到运行结果:

难度分析

⭐️⭐️

总结

通过统计 ID 频次并使用贪心策略选择未使用的 ID,可以高效解决重复 ID 的替换问题,使得每个 ID 在数组中唯一。

相关推荐
flushddd12 分钟前
GOOUUU ESP32-S3-CAM 果云科技开发板开发指南(一)(超详细!)Vscode+espidf 通过摄像头拍摄照片并存取到SD卡中,文末附源码
ide·vscode·编辑器·esp32
CodeWithMe35 分钟前
【C/C++】不同防止头文件重复包含的措施
c语言·开发语言·c++
子豪-中国机器人1 小时前
C++ 信息学奥赛总复习题答案解析
开发语言·c++·算法
弥彦_1 小时前
牛客round95D
c++·算法
whoarethenext1 小时前
使用 C/C++的OpenCV 实现模板匹配:从基础到优化
c语言·c++·opencv
强盛小灵通专卖员2 小时前
基于深度学习RT-DETR算法的盲人障碍物目标检测:提升盲人出行安全的智能化突破
深度学习·算法·目标检测·计算机视觉·rt-detr·小论文·计算机期刊
合方圆~小文2 小时前
架空线路图像视频监测装置
c语言·c++·人工智能·嵌入式硬件·硬件工程·模拟退火算法
我不是小upper2 小时前
统计学核心概念与现实应用精解(偏机器学习)
算法·机器学习·统计学
Renlijuande2 小时前
百度之星2021——BD202104 萌新
算法
卖猪肉的痴汉3 小时前
4.2 C/C++开发环境:VSCode+CMake+MSYS2
c语言·c++·vscode