蓝桥云课 班级活动

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;
}
相关推荐
KarrySmile24 分钟前
Day17--二叉树--654. 最大二叉树,617. 合并二叉树,700. 二叉搜索树中的搜索,98. 验证二叉搜索树
数据结构·算法·二叉树·二叉搜索树·合并二叉树·最大二叉树·验证二叉搜索树
凤年徐26 分钟前
【数据结构与算法】21.合并两个有序链表(LeetCode)
c语言·数据结构·c++·笔记·算法·链表
程序员老冯头34 分钟前
第三十二节 MATLAB函数
数据结构·算法·matlab
lifallen39 分钟前
hadoop.yarn 带时间的LRU 延迟删除
java·大数据·数据结构·hadoop·分布式·算法
淮北4944 小时前
STL学习(十一、常用的算数算法和集合算法)
c++·vscode·学习·算法
糖葫芦君5 小时前
玻尔兹曼分布与玻尔兹曼探索
人工智能·算法·机器学习
花火|10 小时前
算法训练营day37 动态规划⑤ 完全背包 518. 零钱兑换 II、 377. 组合总和 Ⅳ、70. 爬楼梯 (进阶)
算法·动态规划
Neil今天也要学习10 小时前
永磁同步电机无速度算法--脉振方波注入法
算法
绿炮火11 小时前
【MATLAB】(二)基础知识
开发语言·算法·matlab
88号技师11 小时前
2025年6月最新SCI-灰熊脂肪增长优化算法Grizzly Bear Fat Increase-附Matlab免费代码
开发语言·人工智能·算法·matlab·优化算法