蓝桥云课 班级活动

1.班级活动 - 蓝桥云课

问题描述

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

老师希望通过更改若干名同学的 id 使得对于任意一名同学 j 的 id 与其相同(ai​=aj​)。请问老师最少需要更改多少名同学的 id?

输入格式

输入共 2 行。

第一行为一个正整数 n。

第二行为 n 个由空格隔开的整数 a1​,a2​,...,an​。

输出格式

输出共 1 行,一个整数。

样例输入

复制代码
4
1 2 2 3

样例输出

复制代码
1

样例说明

仅需要把 a1​ 改为 3 或者把 a3​ 改为 1 即可。

评测用例规模与约定

对于 20% 的数据,保证 n≤1e3。

对于 100% 的数据,保证 n≤1e5。

思路:

画图+模拟

代码:

复制代码
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll N = 1e5+10;
ll has[N];
ll n,a,b,t;
int main()
{
	cin >> n;
	ll sum = 0;
	for(ll i = 1 ; i <= n ; i++)
	{
		cin >> t;
		has[t]++;
	}
	for(ll i = 0 ; i <= n ; i++)
	{
		if(has[i] == 1)
		{
			a++;
		}
		else if(has[i] >= 2)
		{
			b += has[i] - 2;
		}
	}
	ll ans;
	if(b >= a)
	{
		ans = b;
	}
	else
	{
		ans = (a-b)/2 + b;
	}
	cout << ans;
  	return 0;
}
相关推荐
无限码力3 分钟前
美团研发岗 5月9号笔试真题 - 正整数矩阵
算法·美团笔试真题·美团研发岗笔试真题·美团0509笔试真题
Smilecoc5 分钟前
决策树(二):决策树的划分选择
算法·决策树·机器学习
hetao173383716 分钟前
2026-05-25~06-11 hetao1733837 的刷题记录
c++·算法
cheems952720 分钟前
[算法手记] 滑动窗口最大值
算法
洛水水21 分钟前
【力扣100题】82.有效的括号
c++·算法·leetcode
XGeFei23 分钟前
时序算法 —— LSTM、ARIMA、随机森林
算法·随机森林·lstm
湖南天硕国产SSD42 分钟前
工业存储可靠性进阶:天硕工业固态硬盘动态温控与寿命优化技术实践
网络·数据库·算法·工业存储·天硕存储·工业固态硬盘
legend050709ComeON43 分钟前
常见面试题-leetcode
数据结构·算法·leetcode
Smilecoc1 小时前
决策树(一):决策树基本原理
算法·决策树·机器学习
weixin_307779131 小时前
从工具到协作者:AI在后端研发中的流程重构与组织赋能
人工智能·后端·python·算法·自动化