题目传送门:这里是萌萌哒传送门(>,<)

啊♀,据说这题有个完全贪心的做法,但是要维护太多东西好麻烦的(>,<),于是就来口胡一发三分的做法。

思路很简单,假设我指定了一个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 贪心 三分的更多相关文章

  1. 【BZOJ4868】[六省联考2017]期末考试(贪心)

    [BZOJ4868][六省联考2017]期末考试(贪心) 题面 BZOJ 洛谷 题解 显然最终的答案之和最后一个公布成绩的课程相关. 枚举最后一天的日期,那么维护一下前面有多少天可以向后移,后面总共需 ...

  2. [luogu] P3745 [六省联考2017]期末考试 (贪心)

    P3745 [六省联考2017]期末考试 题目描述 有 \(n\) 位同学,每位同学都参加了全部的 \(m\) 门课程的期末考试,都在焦急的等待成绩的公布. 第 \(i\) 位同学希望在第 \(t_i ...

  3. 六省联考2017 Day1

    目录 2018.3.18 Test T1 BZOJ.4868.[六省联考2017]期末考试 T2 T3 BZOJ.4870.[六省联考2017]组合数问题(DP 矩阵快速幂) 总结 考试代码 T1 T ...

  4. 【BZOJ4873】[六省联考2017]寿司餐厅(网络流)

    [BZOJ4873][六省联考2017]寿司餐厅(网络流) 题面 BZOJ 洛谷 题解 很有意思的题目 首先看到答案的计算方法,就很明显的感觉到是一个最大权闭合子图. 然后只需要考虑怎么构图就行了. ...

  5. 六省联考2017 Day2

    目录 2018.3.27 Test 总结 T1 T2 T3 BZOJ.4873.[六省联考2017]寿司餐厅(最小割ISAP 最大权闭合子图) 考试代码 T1 T2 T3 2018.3.27 Test ...

  6. 洛谷 P3747 [六省联考2017]相逢是问候 解题报告

    P3747 [六省联考2017]相逢是问候 题目描述 \(\text {Informatik verbindet dich und mich.}\) 信息将你我连结. \(B\) 君希望以维护一个长度 ...

  7. P3746 [六省联考2017]组合数问题

    P3746 [六省联考2017]组合数问题 \(dp_{i,j}\)表示前\(i\)个物品,取的物品模\(k\)等于\(r\),则\(dp_{i,j}=dp_{i-1,(j-1+k)\%k}+dp_{ ...

  8. [BZOJ4868][六省联考2017]期末考试(三分)

    4868: [Shoi2017]期末考试 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 964  Solved: 439[Submit][Status ...

  9. BZOJ 4872 luogu P3750 [六省联考2017]分手是祝愿

    4872: [Shoi2017]分手是祝愿 Time Limit: 20 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description ...

随机推荐

  1. Activity 在横竖屏切换情况下的生命周期变化

    title: Activity 在横竖屏切换情况下的生命周期变化 date: 2018-04-26 23:05:57 tags: [Activity] categories: [Mobile,Andr ...

  2. HTML5+Bootstrap 学习笔记 4

    HTML5 <map> <area> 标签 <map> 标签定义客户端的图像映射.图像映射是带有可点击区域的图像. <area> 标签定义图像映射内部的 ...

  3. Requests库入门——应用实例-网络图片的爬取与保存(好看的小姐姐≧▽≦)

    在B站学习这一节的时候,弹幕最为激烈,不管大家是出于什么目的都想体验一下网络爬虫爬取图片的魅力,毕竟之前的实例实话说都是一些没有太大作用的信息. 好了,直接上代码: import requests i ...

  4. 将Python文件打包为exe文件,并在控制台运行之简易教程

       第一步  在线安装 pyinstaller. 方法:打开win+ R,输入cmd,在命令行输入"pip install pyinstaller" 静等几分钟后即可安装成功. ...

  5. Scrum立会报告+燃尽图(十一月十七日总第二十五次):设计调查问卷;修复上一阶段bug

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2284 项目地址:https://git.coding.net/zhang ...

  6. HDU 5234 Happy birthday 01背包

    题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5234 bc:http://bestcoder.hdu.edu.cn/contests/con ...

  7. ubuntu16.04卸载火狐,Amazon

    一.卸载火狐: . dpkg --get-selections |grep firefox .sudo apt-get purge firefox unity-scope-firefoxbookmar ...

  8. DPDK报文分类与访问控制

    原创翻译,转载请注明出处. dpdk提供了一个访问控制库,提供了基于一系列分类规则对接收到的报文进行分类的能力.ACL库用来在一系列规则上执行N元组查找,可以实现多个分类和对每个分类查找最佳匹配(最高 ...

  9. 【week9】psp

    本周psp 项目 内容 开始时间 结束时间 中断时间 净时间 2016/11/14 看论文 蛋白质甲基化位点预测 9:30 13:00 15 195 讨论班 组内讨论班 13:30 17:00 0 2 ...

  10. PAT 甲级 1035 Password

    https://pintia.cn/problem-sets/994805342720868352/problems/994805454989803520 To prepare for PAT, th ...