当前位置: 首页 > article >正文

蓝桥杯每日真题 - 第10天

题目:(班级活动)

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

7d0e93d676104795ba2f1086e92eeac2.png

解题思路:

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

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

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

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

代码实现(C语言):

#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 的计数。

得到运行结果:

e9559abf660f4f498bfc77215f45519b.png

难度分析

⭐️⭐️ 

总结

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


http://www.kler.cn/a/396586.html

相关文章:

  • C语言之MakeFile
  • .NET 9 中 IFormFile 的详细使用讲解
  • WPF中如何使用区域导航
  • maven的optional选项说明以及具体应用
  • C++清除所有输出【DEV-C++】所有编辑器通用 | 算法基础NO.1
  • Javascript中的深浅拷贝以及实现方法
  • [Android]相关属性功能的裁剪
  • Linux---常用shell脚本
  • 力扣654:最大二叉树
  • 【鸿蒙开发】第二十二章 IPC与RPC进程间通讯服务
  • 【LeetCode】【算法】53. 最大子数组和
  • 【日常记录-Git】撤销工作区中所有已跟踪文件的修改
  • Java集合(Collection+Map)
  • 回调函数的概念、意义和应用场景
  • SQL 审核在 CloudQuery 的四大场景应用
  • leetcode hot100【 LeetCode 121.买卖股票的最佳时机】java实现
  • uniapp ios app以framwork形式接入sentry
  • 使用--log-file保存pytest的运行日志
  • WP网站如何增加文章/页面的自定义模板
  • Node.Js+Knex+MySQL增删改查的简单示例(Typescript)
  • 猫狗识别之BUG汇总
  • C++编程技巧与规范-类和对象
  • conda 和 pip 的比较
  • 嵌入式面试题练习 - 2024/11/15
  • NVR小程序接入平台/设备EasyNVR多个NVR同时管理设备接入:海康NVR 3.0提示不在线如何处理?
  • C++- 基于多设计模式下的同步异步日志系统