当前位置: 首页 > news >正文

Luogu P4447 [AHOI2018初中组]分组

题目链接:传送门

nnn个可重复的整数分为mmm组,每组中的数必须连续且不重复,使人数最少的组人数最多。
两个最值肯定第一想到二分,每次二分出一个值,判断在这个值为答案的前提下能否完成分组。
在思考判别函数时发现没有必要二分,单独依靠人数底线也并不能得到最优解,通过贪心就可以直接得到答案。

先将这些数从小到大排序,对每个数进行分组,group[i]group[i]group[i]表示第iii组的末尾的数,可见每组内的数是升序的。
对于一个数a[i]a[i]a[i],遍历现有的所有组,如果有一个组的末尾的数group[i]=a[i]−1group[i]=a[i]-1group[i]=a[i]1,则表示这个数可以接在这组的队尾。
但这样并不能保证最优解,那我们添加一个条件,将这个数加在长度最短的队的队尾,即可保证最优。

#include <bits/stdc++.h>
#define A 100010using namespace std;
int n, a[A];
int num, size[A], group[A];int main(int argc, char const *argv[]) {cin >> n;for (int i = 1; i <= n; i++) scanf("%d", &a[i]);sort(a + 1, a + n + 1);for (int i = 1; i <= n; i++) {int size_min = INT_MAX, pos = 0; bool flag = 0;for (int j = 1; j <= num; j++)if (group[j] + 1 == a[i] and size[j] < size_min)pos = j, flag = 1, size_min = size[j];if (flag) size[pos]++, group[pos] = a[i];else group[++num] = a[i], size[num] = 1;}int ans = INT_MAX;for (int i = 1; i <= num; i++) ans = min(ans, size[i]);cout << ans << endl;
}
http://www.lryc.cn/news/30944.html

相关文章:

  • 手把手创建flask项目
  • SpringCloud-4_Eureka服务注册与发现
  • 【react全家桶】生命周期
  • 虚拟机安装Windows 10
  • 【CMU15-445数据库】bustub Project #2:B+ Tree(下)
  • leetcode 困难 —— 外星文字典(拓扑排序)
  • ubuntu server 18.04使用tensorflow进行ddqn训练全过程
  • 2023年全国最新二级建造师精选真题及答案14
  • mysql一条语句的写入原理
  • 嵌入式Linux内核代码风格(二)
  • Spring Boot @Aspect 切面编程实现访问请求日志记录
  • 初学者的第一个Linux驱动
  • 7. 拼数
  • Java每天15道面试题 | Redis
  • 13_pinctrl子系统
  • Linux系统对于实施人员的价值
  • ForkJoin 和 Stream并行流
  • 逻辑优化-cofactor
  • 车道线检测CondLaneNet论文和源码解读
  • vue3的插槽slots
  • docker学校服务器管理
  • pv和pvc
  • k8s篇之Pod 干预与 PDB
  • Django学习17 -- ManytoManyField
  • 既然有MySQL了,为什么还要有Redis?
  • RSTP基础要点(上)
  • Linux操作系统学习(信号处理)
  • CopyOnWriteArrayList 源码解读
  • 方法
  • C/C++实现发送邮件功能(附源码)