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

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

思路很简单,假设我指定了一个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. while read读取文本内容

    读取文件给 while 循环 方式一: exec <FILE while read line do cmd done 方式二: cat FILE_PATH |while read line do ...

  2. 拉格朗日乘子法与KKT条件 && SVM中为什么要用对偶问题

    参考链接: 拉格朗日乘子法和KKT条件 SVM为什么要从原始问题变为对偶问题来求解 为什么要用对偶问题 写在SVM之前——凸优化与对偶问题 1. 拉格朗日乘子法与KKT条件 2. SVM 为什么要从原 ...

  3. AngularJS - 路由 routing 基础示例

    AngularJS 路由 routing 能够从页面的一个视图跳转到另外一个视图,对单页面应用来讲是至关重要的.当应用变得越来越复杂时,我们需要一个合理的方式来管理用户在使用过程中看到的界面.Angu ...

  4. java 数据存储

    简单的记录一下而已. 1.寄存器: 特点:快,存储有限. 存储地点:处理器内部. 2.堆栈 特点:仅次于寄存器快,通过堆栈指针在处理器获取支持.堆栈指针下移,分配内存,上移,释放内存.此外须知生命周期 ...

  5. PSP表格记录功能

    关于王者荣耀交流协会的PSP表格记录功能,就是针对我们平时做表格时候遇到问题的简化与解决.这部分功能可以记录我们开始时间,暂停时间,结束时间,并自动计算出各个时间段的净时间.只要你开始工作时点一下开始 ...

  6. 软工1816 · Alpha冲刺(6/10)

    团队信息 队名:爸爸饿了 组长博客:here 作业博客:here 组员情况 组员1(组长):王彬 过去两天完成了哪些任务 alpha冲刺时间延后一周,重新规划任务安排 完成食堂店铺经纬度标注,以供美食 ...

  7. 博弈---尼姆博奕(Nimm Game)(重点)

    尼姆博奕(Nimm Game):有三堆各若干个物品,两个人轮流从某一堆取任意多的 物品,规定每次至少取一个,多者不限,最后取光者得胜. 这种情况最有意思,它与二进制有密切关系,我们用(a,b,c)表示 ...

  8. Linux安装weblogic

    一.软件安装 1. 安装前的准备工作 1.1 首先请确认您要安装的WebLogic版本所在的平台已通过了BEA的认证,完整的认证平台列表请参考 http://e-docs.bea.com/wls/ce ...

  9. oracle 不能是用变量来作为列名和表名 ,但使用动态sql可以;

    ORACLE 不能使用变量来作为列名 和表名 一下是个人的一些验证: DECLARE ename1 emp.ename%TYPE ; TYPE index_emp_type ) INDEX BY PL ...

  10. 虚拟机Centos设置静态IP

    首先确保虚拟网卡(VMware Network Adapter VMnet8)是开启的,然后在windows的命令行里输入“ipconfig /all”,找到VMware Network Adapte ...