题意

给你n个非负整数的数列a,你可以进行K次操作,每次操作可以将任意位置的数数更改成任意一个非负整数,求操作以后,DIFF(a)-MEX(a)的最小值;DIFF代表数组中数的种类。MEX代表数组中未出现的最小自然数。

提示

1. 显然 DIFF(a)-MEX(a)最小,DIFF(a)越小越好,MEX(a)越大越好

2. 假如 DIFF 降低,同时 MEX 提升,这样操作是不亏的,因此我们只需要提升MEX即可,贪心的的构造0-x,x为k次修改,能构建到mex的最大的数列a状态。

3. 在原始a中,0-x中空缺的值即为需要填充个数的值,我们只需要贪心,先填入出现次数少的>x的值,以降低它的DIFF,即MEX固定了,再降低其DIFF

代码

#include<bits/stdc++.h>

using namespace std;
int a[100005], cnt[100005];
map<int, int> mp;
struct node {
int x, y;
} op[100005]; void run() {
int n, k;
cin >> n >> k;
for (int i = 0; i <= n; i++) {
cnt[i] = 0;
}
set<int> s;
mp.clear();
for (int i = 1; i <= n; i++) {
cin >> a[i];
if (a[i] < n)cnt[a[i]]++;
s.insert(a[i]);
mp[a[i]]++;
} int res = 0, flag = n;
for (int i = 0; i < n; i++) {
if (cnt[i] == 0)res++;
if (res > k) {
flag = i;
break;
}
}
int st = 0;
for (auto [x, y]: mp) {
if (x >= flag)op[++st] = {x, y};
}
sort(op + 1, op + 1 + st, [&](const node &x, const node &y) { return x.y < y.y; });
int sum = 0;
int ree = min(res, k);
for (int i = 1; i <= st; i++) {
ree -= op[i].y;
if (ree >= 0)sum++;
else break;
}
cout << min(res, k) - sum + int(s.size()) - flag << '\n';
} int main() {
int t;
cin >> t;
while (t--)
run();
return 0;
}

最新文章

  1. 基于MVC4+EasyUI的Web开发框架经验总结(17)--布局和对话框自动适应大小的处理
  2. Redmine新建问题速度慢
  3. hdu1402 FFT入门
  4. jquery 获取radio选中的值
  5. WebApi传参总动员(二)
  6. UWP开发中的方向传感器
  7. C++ 牛人博客(不断更新中...)
  8. 信驰达携“Zigbee Light Link灯控方案”亮相第18届广州国际照明展
  9. android开发之Fragment加载到一个Activity中
  10. 【BZOJ 1031】[JSOI2007]字符加密Cipher
  11. LESSCSS
  12. awk学习笔记一:基础(转)
  13. 求求别再这么用log4x了
  14. ABP Zero示例项目问题总结
  15. 什么是移动BI
  16. Linux下网络配置与修改Centos7为列
  17. ubuntu中如何安装python3.6
  18. MySQL安装脚本0104-亲试ok
  19. eslint那些事儿
  20. centos6.9 编译安装 zabbix-3.0.15

热门文章

  1. Sphere类定义
  2. 海豚调度5月Meetup:6个月重构大数据平台,帮你避开调度升级改造/集群迁移踩过的坑
  3. Win32 - 窗口
  4. [跨数据库、微服务] FreeSql 分布式事务 TCC/Saga 编排重要性
  5. 详解MySQL隔离级别
  6. Maven中使用ssm框架出现:org.apache.tomcat.util.modeler.BaseModelMBean.invoke 调用方法[manageApp]时发生异常
  7. 业务流程可视化-让你的流程图&quot;Run&quot;起来(7.运行状态持久化&amp;轻量工作流支持)
  8. .NET 7 性能改进 -- 至今为止最快的.NET平台
  9. Linux 更换国内源
  10. Keepalived之简单有效的配置