【题解】期末考试 六省联考 2017 洛谷 P3745 BZOJ 4868 贪心 三分
题目传送门:这里是萌萌哒传送门(>,<)
啊♀,据说这题有个完全贪心的做法,但是要维护太多东西好麻烦的(>,<),于是就来口胡一发三分的做法。
思路很简单,假设我指定了一个x,要求通过调整,所有的成绩都最迟在第x天出。
调整到第x天的代价是很容易通过贪心计算出来的啦,复杂度线性。
然后我们考虑从大到小枚举x,每次计算出代价之后更新答案。
再然后我们大胆猜想这是一个单峰函数!
既然都单峰啦那直接三分就好啦(>,<)。
实际上我不知道它是不是真的是单峰函数。。。但是就AC了。。。
如果这个做法能被叉掉的话欢迎dalao来叉♀啦,求轻虐。。。
#include <cstring>
#include <algorithm>
#include <cstdio>
using namespace std;
typedef long long ll;
const ll INFLL = 0x3f3f3f3f3f3f3f3fLL;
const int MAXN = 100010;
const int MAXM = 100010;
ll A, B, C;
int n, m, t[MAXN], b[MAXM];
void input() {
scanf( "%lld%lld%lld", &A, &B, &C );
scanf( "%d%d", &n, &m );
for( int i = 0; i < n; ++i ) scanf( "%d", t+i );
for( int i = 0; i < m; ++i ) scanf( "%d", b+i );
}
ll f( int lim ) { // 贪心计算最迟在第lim天出所有成绩的最小代价
ll y = 0;
ll left = 0, extra = 0;
for( int i = 0; i < n; ++i )
if( lim > t[i] ) y += (lim - t[i])*C;
for( int i = 0; i < m; ++i ) {
if( b[i] < lim ) left += lim - b[i];
else extra += b[i] - lim;
}
A = min(A, B);
left = min(left, extra);
y += left*A + (extra - left)*B;
return y;
}
void solve() { // 三分
int low = *min_element(t, t+n);
int high = *max_element(b, b+m);
ll ans = INFLL;
while( high-low >= 4 ) {
int lm = low + (high-low)/3;
int rm = high - (high-low)/3;
if( f(lm) < f(rm) ) high = rm;
else low = lm;
}
for( int i = low; i <= high; ++i )
ans = min(ans, f(i));
printf( "%lld\n", ans );
}
void solve2() { // 对于C=1e16的特殊数据,必须要满足所有学生的需求
int lim = *min_element(t, t+n);
ll left = 0, extra = 0;
for( int i = 0; i < m; ++i ) {
if( b[i] < lim ) left += lim - b[i];
else extra += b[i] - lim;
}
A = min(A, B);
left = min(left, extra);
ll ans = left*A + (extra - left)*B;
printf( "%lld\n", ans );
}
int main() {
input();
if( C == ll(1e16) ) solve2();
else solve();
return 0;
}
【题解】期末考试 六省联考 2017 洛谷 P3745 BZOJ 4868 贪心 三分的更多相关文章
- 【BZOJ4868】[六省联考2017]期末考试(贪心)
[BZOJ4868][六省联考2017]期末考试(贪心) 题面 BZOJ 洛谷 题解 显然最终的答案之和最后一个公布成绩的课程相关. 枚举最后一天的日期,那么维护一下前面有多少天可以向后移,后面总共需 ...
- [luogu] P3745 [六省联考2017]期末考试 (贪心)
P3745 [六省联考2017]期末考试 题目描述 有 \(n\) 位同学,每位同学都参加了全部的 \(m\) 门课程的期末考试,都在焦急的等待成绩的公布. 第 \(i\) 位同学希望在第 \(t_i ...
- 六省联考2017 Day1
目录 2018.3.18 Test T1 BZOJ.4868.[六省联考2017]期末考试 T2 T3 BZOJ.4870.[六省联考2017]组合数问题(DP 矩阵快速幂) 总结 考试代码 T1 T ...
- 【BZOJ4873】[六省联考2017]寿司餐厅(网络流)
[BZOJ4873][六省联考2017]寿司餐厅(网络流) 题面 BZOJ 洛谷 题解 很有意思的题目 首先看到答案的计算方法,就很明显的感觉到是一个最大权闭合子图. 然后只需要考虑怎么构图就行了. ...
- 六省联考2017 Day2
目录 2018.3.27 Test 总结 T1 T2 T3 BZOJ.4873.[六省联考2017]寿司餐厅(最小割ISAP 最大权闭合子图) 考试代码 T1 T2 T3 2018.3.27 Test ...
- 洛谷 P3747 [六省联考2017]相逢是问候 解题报告
P3747 [六省联考2017]相逢是问候 题目描述 \(\text {Informatik verbindet dich und mich.}\) 信息将你我连结. \(B\) 君希望以维护一个长度 ...
- P3746 [六省联考2017]组合数问题
P3746 [六省联考2017]组合数问题 \(dp_{i,j}\)表示前\(i\)个物品,取的物品模\(k\)等于\(r\),则\(dp_{i,j}=dp_{i-1,(j-1+k)\%k}+dp_{ ...
- [BZOJ4868][六省联考2017]期末考试(三分)
4868: [Shoi2017]期末考试 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 964 Solved: 439[Submit][Status ...
- BZOJ 4872 luogu P3750 [六省联考2017]分手是祝愿
4872: [Shoi2017]分手是祝愿 Time Limit: 20 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description ...
随机推荐
- JAVA学习笔记--初识容器类库
一.前言 JAVA中一切皆为对象,因而,持有对象显得尤为重要. 在JAVA中,我们可以通过创建一个对象的引用的方式来持有对象: HoldingObject holding; 也可以创建一个对象数组来持 ...
- 基于Docker Compose构建的MySQL MHA集群
Docker MySQL MHA 基于Docker 1.13.1之上构建的MySQL MHA Docker Compose Project 可快速启动GTID模式下的MasterHA集群, 主用于My ...
- mysql常用语句入门整理
这篇属于小白入门级别,如果你已经高手可以直接跳过 1.运行数据库mysqld.exe,客户端直接mysql -uroot(root是默认用户名) -p 2 showdatabases,showtabl ...
- 4个数的和为0 51nod 1267
给出N个整数,你来判断一下是否能够选出4个数,他们的和为0,可以则输出"Yes",否则输出"No". Input 第1行,1个数N,N为数组的长度(4 < ...
- 扩展欧几里德 SGU 106
题目链接:http://acm.sgu.ru/problem.php?contest=0&problem=106 题意:求ax + by + c = 0在[x1, x2], [y1, y2 ...
- BETA阶段第一天
1.提供当天站立式会议照片一张 2.每个人的工作 今天完成工作 林一心 服务器调试 张杭镖 数据库调整 赵意 前端设计 江鹭涛 前端设计 3.发布项目燃尽图 4.每日每人总结 林一心:服务器端的配置不 ...
- Scrum 项目 5.0
5.0--------------------------------------------------- 1.团队成员完成自己认领的任务. 2.燃尽图:理解.设计并画出本次Sprint的燃尽图的理 ...
- IT行业所面临的问题
在阅读了“2015 IT行业大学生就业分析报告”和“2014年十大最热门行业和职业排行榜 IT行业最吃香_联展新闻”两则新闻后,我决定用一篇和老师对话的形式来表达我的感受. dym:人潮汹涌的招聘市场 ...
- QSharedMemory共享内存实现进程间通讯(IPC)及禁止程序多开
版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:QSharedMemory共享内存实现进程间通讯(IPC)及禁止程序多开 本文地址:h ...
- PAT 甲级 1132 Cut Integer
https://pintia.cn/problem-sets/994805342720868352/problems/994805347145859072 Cutting an integer mea ...