蓝桥云课 班级活动

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;
}
相关推荐
sin_hielo2 分钟前
leetcode 2092(排序+bfs)
算法·leetcode·宽度优先
C雨后彩虹13 分钟前
斗地主之顺子
java·数据结构·算法·华为·面试
鸽鸽程序猿26 分钟前
【刷题册】二
算法
CoderCodingNo35 分钟前
【GESP】C++四级真题 luogu-B4416 [GESP202509 四级] 最长连续段
开发语言·c++·算法
xjxijd35 分钟前
工业元宇宙 IDC 支撑:数字孪生算法 + 边缘服务器,生产调度响应速度提 3 倍
运维·服务器·算法
xwz小王子1 小时前
UniBYD:超越人类示教模仿的跨实体机器人操作学习统一框架
学习·算法·机器人·跨实体
跨境卫士苏苏1 小时前
突围新品广告泥潭:亚马逊广告底层逻辑大重构
大数据·人工智能·算法·重构·亚马逊·防关联
旧梦吟2 小时前
脚本网页 三人四字棋
前端·数据库·算法·css3·html5
凯_kyle2 小时前
Python 算法竞赛 —— 基础篇(更新ing)
笔记·python·算法
lizz312 小时前
C++操作符重载深度解析
java·c++·算法