蓝桥杯-班级活动

ops/2024/10/22 13:40:59/

题目描述

小明的老师准备组织一次班级活动。班上一共有 ( n ) 名(( n ) 为偶数)同学,老师想把所有的同学进行分组,每两名同学一组。为了公平,老师给每名同学随机分配了一个 ( n ) 以内的正整数作为 id,第 ( i ) 名同学的 id 为 ( a_i )。

老师希望通过更改若干名同学的 id 使得对于任意一名同学 ( i ),有且仅有另一名同学 ( j ) 的 id 与其相同(( a_i = a_j ))。请问老师最少需要更改多少名同学的 id?

输入格式

输入共 2 行。

第一行为一个正整数 ( n )。

第二行为 ( n ) 个由空格隔开的整数 ( a_1, a_2, …, a_n )。

输出格式

输出共 1 行,一个整数。

输入输出样例

输入 #1

4
1 2 2 3

输出 #1

1

说明/提示

样例说明
仅需要把 ( a_1 ) 改为 3 或者把 ( a_4 ) 改为 1 即可。

评测用例规模与约定

  • 对于 20% 的数据,保证 ( n <= 10^3 )。
  • 对于 100% 的数据,保证 ( n <= 10^5 )。

题解:

一共有两种情况

  1. 只出现过一次的id个数 cnt1 >= 出现过2次以上的id个数 cnt2。 此时把 所有cnt2 都更改成一个id只出现过一次的, 再加上剩下的 cnt1 / 2
  2. 只出现过一次的id个数 cnt1 < 出现过2次以上的id个数 cnt2。 此时把 cnt1个cnt2 都改成一个id只出现过一次的, 再加上剩下的 cnt2 /2

ps: 说白了就是 当有cnt1的时候, 尽可能把cnt2变成cnt1, 当cnt2有剩余的话, 还需要改变 “剩余的cnt2的个数” 次, 当cnt1有剩余的话, 还需要改变 “剩余的cnt1的个数 / 2”

ac代码👇

#include <bits/stdc++.h>
using namespace std;unordered_map<int,int> mp;
int main()
{int n; cin >> n;for (int i = 0; i < n; i ++) {int x; cin >> x;mp[x] ++;}int cnt1 = 0, cnt2 = 0;for (auto it : mp){if (it.second == 1) cnt1 ++;  // id出现过一次的个数if (it.second > 2) cnt2 += it.second - 2;  // id出现次数大于2的都要改成别的id}if (cnt2 - cnt1 >= 0) cout << cnt1 + (cnt2 - cnt1) << endl;  // 情况1else  cout << cnt2 + (cnt1 - cnt2) / 2 << endl;    // 情况2return 0;	
}

觉得写的不错的话, 点个赞吧~


http://www.ppmy.cn/ops/45502.html

相关文章

Lua 基础 03 常用函数

Lua 基础相关知识 第三期 字符串 格式化字符串 string.format 通常字符串的连接可以使用 .. 符号&#xff0c;不过当字符串比较长&#xff0c;这样的连接方式就很繁琐&#xff0c;这时可以使用 string.format 进行格式化。 常用的格式控制符&#xff1a; %s 接收一个字符串…

C语言:结构体(详细讲解)

目录 结构体类型的声明 结构声明 描述一个学生 结构体的创建和初始化​编辑 结构体的⾃引⽤ 结构体的特殊声明 结构体内存对⻬ 对⻬规则 练习1 练习2 练习3 练习4-结构体嵌套问题 为什么会存在内存对⻬ 修改默认对⻬数 结构体的传参 结构体实现位段 什么是位段…

uni-app App端实现文字语音播报(Ba-TTS)

前言 最近在遇到消息提示语音播放出来&#xff0c;查了一圈文档发现并没有自带api 后面想起支付宝收钱播报&#xff0c;不受限与系统环境和版本环境&#xff08;后面查阅他是音频实现的&#xff09; 如果是由安卓端需要语音播放功能-直接使用Ba-TTs救急&#xff08;需要付费2…

VSCODE 常用快捷键

快捷按键 注释 CTRL /CTRL KSHIFT ALT A取消注释 CTRL /CTRL KSHIFT ALT A搜索文件 Ctrl P移动到某一行 Ctrl g打开一个新窗口 Ctrl Shift N关闭窗口 Ctrl Shift W新建文件 Ctrl N文件间切换 Ctrl Tab全部文件搜索 Ctrl Shift F全屏 F11 打开文件出现中文乱码 文件右下角…

C++第二十二弹---vector深度剖析及模拟实现(下)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】 目录 1、容量操作 2、内容修改操作 3、打印函数 4、迭代器失效 4.1、什么是迭代器失效 4.2、哪些操作会引起迭代器失效 总结 1、容量操作 size()…

UE5 双手握剑的实现(逆向运动学IK)

UE5 双手握剑的实现 IK 前言 什么是IK&#xff1f; UE官方给我们提供了很多对于IK处理的节点&#xff0c;比如ABRIK、Two Bone IK、Full Body IK 、CCD IK等&#xff0c;但是看到这&#xff0c;很多人就好奇了&#xff0c;什么是IK&#xff1f; 首先我们来看看虚幻小白人的骨…

Vue基础(3)监听数据

1. 监听 ref <script setup> import { ref, watch} from vueconst count ref(0) watch(count, (newValue, oldValue) > {console.log(count changed from ${oldValue} to ${newValue}) }) </script><template><button click"count">{{ …

Vue3上传下载的样式模版 | 附Demo(Vue3 + Java)

目录 前言1. 基本知识2. Demo3. 彩蛋3.1 下载3.2 上传 前言 基本的Vue3知识推荐阅读&#xff1a;Vue 目录 1. 基本知识 对于下述Demo涉及以下知识点&#xff1a; Vue 组件基础 使用 defineComponent 定义一个 Vue 组件 script setup 是一种新的 <script> 语法糖&…