NC20439 [SHOI2017]期末考试
NC20439 [SHOI2017]期末考试
题目
题目描述
有 \(n\) 位同学,每位同学都参加了全部的 \(m\) 门课程的期末考试,都在焦急的等待成绩的公布。第 \(i\) 位同学希望在第 \(t_i\) 天或之前得知所有课程的成绩。如果在第ti天,有至少一门课程的成绩没有公布,他就会等待最后公布成绩的课程公布成绩,每等待一天就会产生 \(C\) 不愉快度。对于第 \(i\) 门课程,按照原本的计划,会在第 \(b_i\) 天公布成绩。有如下两种操作可以调整公布成绩的时间:
1.将负责课程 \(X\) 的部分老师调整到课程 \(Y\) ,调整之后公布课程 \(X\) 成绩的时间推迟一天,公布课程 \(Y\) 成绩的时间提前一天;每次操作产生 \(A\) 不愉快度。
2.增加一部分老师负责学科 \(Z\) ,这将导致学科 \(Z\) 的出成绩时间提前一天;每次操作产生 \(B\) 不愉快度。
上面两种操作中的参数 \(X,Y,Z\) 均可任意指定,每种操作均可以执行多次,每次执行时都可以重新指定参数。
现在希望你通过合理的操作,使得最后总的不愉快度之和最小,输出最小的不愉快度之和即可
输入描述
第一行三个非负整数 \(A,B,C\) ,描述三种不愉快度,详见【问题描述】;
第二行两个正整数 \(n,m(1 ≤ n,m ≤ 10^5)\) , 分别表示学生的数量和课程的数量;
第三行 \(n\) 个正整数 \(t_i\) ,表示每个学生希望的公布成绩的时间;
第四行 \(m\) 个正整数 \(b_i\) ,表示按照原本的计划,每门课程公布成绩的时间。
\(1 ≤ N,M,T_i,B_i ≤ 100000,0 ≤ A,B,C ≤ 100000\)
输出描述
输出一行一个整数,表示最小的不愉快度之和。
示例1
输入
100 100 2
4 5
5 1 2 3
1 1 2 3 3
输出
6
说明
由于调整操作产生的不愉快度太大,所以在本例中最好的方案是不进行调整; 全部
5 的门课程中,最慢的在第 3 天出成绩;
同学 1 希望在第 5 天或之前出成绩,所以不会产生不愉快度;
同学 2 希望在第 1 天或之前出成绩,产生的不愉快度为 (3 - 1) * 2 = 4;
同学 3 希望在第 2 天或之前出成绩,产生的不愉快度为 (3 - 2) * 2 = 2;
同学 4 希望在第 3 天或之前出成绩,所以不会产生不愉快度;
不愉快度之和为 4 + 2 = 6 。
备注
数据范围
题解
思路
知识点:三分。
三分最晚的公布的时间,因为其符合单调性,晚于或早于这个时间的最晚公布时间造成的不满意度都会变大,B则答案时间在峰谷。
通过计算最晚时间 \(mid\) 的最优不满意度进行检验答案。先遍历数组计算超时总额 \(need\) 和多余总额 \(rest\) ,\(rest\) 用于操作 \(1\) 。注意到,若 \(A\geq B\) 肯定优先用操作 \(2\) 提前所有超时课的公布时间,花费是 \(B \cdot need\) ;若 \(A<B\) ,优先用操作 \(1\) ,但可能 \(rest\) 不够,需要用操作 \(2\) 补齐剩余的 \(need\) ,够用的花费是 \(A \cdot need\) ,不够用的花费是 \(A \cdot rest + B \cdot (need - rest)\) 。最后累加 \(C\cdot max(mid-T[i])\) ,得到调整后的学生不满意度,返回花费总和进行比较。
时间复杂度 \(O((m+n)\log B_{max})\)
空间复杂度 \(O(m+n)\)
代码
#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll a, b, c;
int n, m;
int T[100007], B[100007];
ll calc(int mid) {
ll need = 0, rest = 0, ans = 0;
for (int i = 0;i < m;i++) {
if (B[i] <= mid) rest += mid - B[i];
else need += B[i] - mid;
}
if (b <= a) ans += need * b;
else {
if (need <= rest) ans += need * a;
else ans += rest * a + (need - rest) * b;
}
for (int i = 0;i < n;i++) ans += max(mid - T[i], 0) * c;
return ans;
}
int main() {
std::ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
cin >> a >> b >> c >> n >> m;
for (int i = 0;i < n;i++) cin >> T[i];
for (int i = 0;i < m;i++) cin >> B[i];
int l = 1, r = *max_element(B, B + m);
while (l <= r) {
int mid1 = l + (r - l) / 3;
int mid2 = r - (r - l) / 3;
if (calc(mid1) <= calc(mid2)) r = mid2 - 1;
else l = mid1 + 1;
}
cout << calc(l) << '\n';
return 0;
}
NC20439 [SHOI2017]期末考试的更多相关文章
- bzoj4868: [Shoi2017]期末考试(三分法)
4868: [Shoi2017]期末考试 题目:传送门 题解: Get到一个新姿势...三分法 一开始百度百科的时候下了一跳...中国...的根??? 学懂了之后其实运用起来就根二分差不多啊,不过证明 ...
- bzoj 4868: [Shoi2017]期末考试
Description 有n位同学,每位同学都参加了全部的m门课程的期末考试,都在焦急的等待成绩的公布.第i位同学希望在第ti天 或之前得知所.有.课程的成绩.如果在第ti天,有至少一门课程的成绩没有 ...
- [bzoj4868][Shoi2017]期末考试
来自FallDream 的博客,未经允许,请勿转载,谢谢. 有n位同学,每位同学都参加了全部的m门课程的期末考试,都在焦急的等待成绩的公布.第i位同学希望在第ti天或之前得知所.有.课程的成绩.如果在 ...
- BZOJ4868:[SHOI2017]期末考试——题解
http://www.lydsy.com/JudgeOnline/problem.php?id=4868 题目复制于洛谷:https://www.luogu.org/problemnew/show/P ...
- [SHOI2017]期末考试
题目描述 有n位同学,每位同学都参加了全部的m门课程的期末考试,都在焦急的等待成绩的公布. 第i位同学希望在第ti天或之前得知所有课程的成绩.如果在第ti天,有至少一门课程的成绩没有公布,他就会等待最 ...
- 【bzoj4868】[Shoi2017]期末考试 前缀和+暴力
题目描述 有n位同学,每位同学都参加了全部的m门课程的期末考试,都在焦急的等待成绩的公布.第i位同学希望在第ti天或之前得知所.有.课程的成绩.如果在第ti天,有至少一门课程的成绩没有公布,他就会等待 ...
- BZOJ-1- 4868: [Shoi2017]期末考试-三分
三分出成绩时间,假设当前出成绩最优,那么提前就会调增老师,增加不愉快度多于少等待的:如果延迟时间. 那么等待更久,增加的不愉快度也将多余少调增剩省下的. 于是:对于当前点,两边都是有单调性的. 就是说 ...
- BZOJ4868 [Shoi2017]期末考试 【三分 + 贪心】
题目链接 BZOJ4868 题解 最后的答案决定于最后一个公布的成绩 显然这个是答案关于这个时间点是呈凸单调的 三分一下这个时间点 时间点固定,在这个时间前的人都会产生不愉快度,在这个时间前的科目可以 ...
- BZOJ4868 Shoi2017期末考试(三分+贪心)
容易想到枚举最晚发布成绩的课哪天发布,这样与ti和C有关的贡献固定.每门课要么贡献一些调节次数,要么需要一些调节次数,剩下的算贡献也非常显然.这样就能做到平方级别了. 然后大胆猜想这是一个凸函数三分就 ...
随机推荐
- Math内置对象 常用的方法
属性: Math.Pi 方法: Math.max() 最大值 Math.min() 最小值 Math.ceil() 向上取整 Math.floor() 向下取整 Math.random() ...
- 利用java反射机制实现List>转化为List
BEGIN; 最近在用hibernate做项目,由于后续的业务功能比较多,然后框架原设计没有使用到一对多.一对一等特性,(艹TA妹)没办法,只能用原生sql语句获得需要的结果集.但是返回过来的是一个L ...
- CentOS下Apache Doris Oracle ODBC外表使用指南
1.软件环境 操作系统:CentOS 7.8 Apache Doris :0.15 Postgresql数据库:oracle 19c UnixODBC:2.3.1 Oracle ODBC :insta ...
- HMS Core Discovery第14期回顾长文|纵享丝滑剪辑,释放视频创作力
HMS Core Discovery第14期直播<纵享丝滑剪辑,释放视频创作力>,已于4月21日圆满结束,本期直播我们同HMS Core视频编辑服务(Video Editor Kit)的产 ...
- 『现学现忘』Git对象 — 17、Commit对象
目录 1.Commit对象介绍 2.Commit对象说明 3.本地库中对象之间的关系 4.总结 5.练习 6.本文用到的命令总结 1.Commit对象介绍 现在来介绍最后一种Git对象commit对象 ...
- 解析数仓OLAP函数:ROLLUP、CUBE、GROUPING SETS
摘要:GaussDB(DWS) ROLLUP,CUBE,GROUPING SETS等OLAP函数的原理解析. 本文分享自华为云社区<GaussDB(DWS) OLAP函数浅析>,作者: D ...
- Azure Terraform(十一)Azure DevOps Pipeline 内的动态临时变量的使用
思路浅析 在我们分析的 Azure Terraform 系列文中有介绍到关于 Terraform 的状态文件远程存储的问题,我们在 Azure DevOps Pipeline 的 Task Job ...
- Halo 开源项目学习(七):缓存机制
基本介绍 我们知道,频繁操作数据库会降低服务器的系统性能,因此通常需要将频繁访问.更新的数据存入到缓存.Halo 项目也引入了缓存机制,且设置了多种实现方式,如自定义缓存.Redis.LevelDB ...
- LintCode-165 · 合并两个排序链表-题解
描述:将两个排序(升序)链表合并为一个新的升序排序链表样例 1:输入: list1 = null, list2 = 0->3->3->null输出: 0->3->3-&g ...
- 思索 p5.js 的最佳实践
思索 p5.js 的最佳实践 本文写于 2020 年 12 月 18 日 p5.js 是一个 JavaScript 库,用于为艺术家.设计师提供更容易上手的创意编程. 它有着完整的一套基于 Canva ...