【题解】CF1056F Write the Contest(三分+贪心+DP)

最优化问题的三个解决方法都套在一个题里了,真牛逼

最优解应该是怎样的,一定存在一种最优解是先完成了耗时长的任务再干别的(不干白不干啊),所以我们按照耗时先排序。

假设你最优解是去事件\(e_1,e_2,e_3,e_4\),你可以在规定时间里干完,那么你如果按照耗时从大往小干也一定可以干完。

好像只能找到"按照耗时从大往小干"一种钦定方法使得所有方案可以归纳到这种情况

考虑最终耗时是怎样的:\(t\)表示练习用的时间

\[f(t)=\dfrac {\sum(\dfrac {10} 9)^i a_{h_i}} {s_0+Ct}+10t
\]

我们转化一下思路,设\(dp(i,j)\)表示选择\(i\)个任务做并且将会获得收益\(j\)的的最小的\(\sum(\dfrac {10} 9)^i a_{h_i}\),这样的设置状态类似于那个Jury一题,【题解】Jury Compromise(链表+DP)。转移显然不讲了。

现在我们要使得\(f(t)=\dfrac {dp(i,j)} {s_0+Ct}+10t\)满足条件并且使得\(j\)最大,由于\(i,j\le O(n)\)所以直接\(n^2\)枚举即可,现在的问题就变成了最小化这个东西\(f(t)\),显然这个函数有单峰且最小(类双勾函数),所以直接三分即可。

//@winlere
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm> using namespace std; typedef long long ll;
inline int qr(){
register int ret=0,f=0;
register char c=getchar();
while(c<48||c>57)f|=c==45,c=getchar();
while(c>=48&&c<=57) ret=ret*10+c-48,c=getchar();
return f?-ret:ret;
}
const int maxn=1001;
long double dp[maxn][maxn];
const long double delta=(long double)9/10;
const long double eps=1e-5;
typedef pair < int , int > P;
P data[maxn];
// a c #define f(x) (( (x)+dp[t][k]/(1+C*(x)) )) long double mi[maxn];
int main(){
//freopen("gamemag.in","r",stdin);
//freopen("gamemag.out","w",stdout);
mi[0]=1;
for(register int t=1;t<maxn;++t) mi[t]=mi[t-1]/delta;
for(register int T00=qr();T00;--T00){
int n;
long double C,T;
cin>>n>>C>>T;
for(register int t=1;t<=n;++t)
data[t].first=qr(),data[t].second=qr();
sort(data+1,data+(int)n+1,[](const P&a,const P&b){return a>b;});
for(register int t=0;t<maxn;++t)
for(register int i=0;i<maxn;++i)
dp[t][i]=1e18;
dp[0][0]=0;
for(register int t=1;t<=n;++t){
for(register int i=t;i;--i){
for(register int k=data[t].second;k<=i*10;++k){
dp[i][k]=min(dp[i][k],dp[i-1][k-data[t].second]+data[t].first*mi[i]);
}
}
}
int ans=0;
for(register int t=1;t<=n;++t){
for(register int k=ans+1;k<=10*t;++k){
//cout<<dp[t][k]<<endl;
long double l=0,r=T,ll,rr;
do{
ll=l+(r-l)/3;
rr=r-(r-l)/3;
if(f(ll)<f(rr)) r=rr;
else l=ll;
}while(l+eps<r);
if(f(l)+10ll*t<T) ans=max(ans,k);
}
}
cout<<ans<<endl;
}
return 0;
}

【题解】CF1056F Write the Contest(三分+贪心+DP)的更多相关文章

  1. 【bzoj5073】[Lydsy1710月赛]小A的咒语 后缀数组+倍增RMQ+贪心+dp

    题目描述 给出 $A$ 串和 $B$ 串,从 $A$ 串中选出至多 $x$ 个互不重合的段,使得它们按照原顺序拼接后能够得到 $B$ 串.求是否可行.多组数据. $T\le 10$ ,$|A|,|B| ...

  2. 【bzoj3174】[Tjoi2013]拯救小矮人 贪心+dp

    题目描述 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以碰到陷阱口.对于每一个小矮人,我们知道他从脚 ...

  3. hdu 1257 最少拦截系统【贪心 || DP——LIS】

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1257 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  4. 贪心+DP【洛谷P4823】 [TJOI2013]拯救小矮人

    P4823 [TJOI2013]拯救小矮人 题目描述 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀上,知道最顶端的小矮人伸直胳膊可以 ...

  5. 【BZOJ-3174】拯救小矮人 贪心 + DP

    3174: [Tjoi2013]拯救小矮人 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 686  Solved: 357[Submit][Status ...

  6. BZOJ_3174_[Tjoi2013]拯救小矮人_贪心+DP

    BZOJ_3174_[Tjoi2013]拯救小矮人_贪心+DP Description 一群小矮人掉进了一个很深的陷阱里,由于太矮爬不上来,于是他们决定搭一个人梯.即:一个小矮人站在另一小矮人的 肩膀 ...

  7. 洛谷P4823 拯救小矮人 [TJOI2013] 贪心+dp

    正解:贪心+dp 解题报告: 传送门! 我以前好像碰到过这题的说,,,有可能是做过类似的题qwq? 首先考虑这种显然是dp?就f[i][j]:决策到了地i个人,跑了j个的最大高度,不断更新j的上限就得 ...

  8. Codeforces Round #401 (Div. 2) A B C 水 贪心 dp

    A. Shell Game time limit per test 0.5 seconds memory limit per test 256 megabytes input standard inp ...

  9. BZOJ_1229_[USACO2008 Nov]toy 玩具_三分+贪心

    BZOJ_1229_[USACO2008 Nov]toy 玩具_三分+贪心 Description 玩具 [Chen Hu, 2006] Bessie的生日快到了, 她希望用D (1 <= D ...

随机推荐

  1. HZOJ 分组

    打了好多个代码. 对于测试点1,11:手动模拟. void QJ1_11() { ) { int tk; ]+a[]))tk=; ; if(tk<=k) { puts("); puts ...

  2. python如何自动发送邮件

    #coding=utf-8 import smtplib from email.mime.text import MIMEText from email.mime.application import ...

  3. 神经网络入门——7or 感知器

    OR 感知器 OR 感知器与 AND 感知器很类似,在下图中,OR 感知器与 AND 感知器有相同的分割线,只是 OR 感知器分割线下移了一段距离.对权重或者偏置做怎样的设置可以实现这个效果?用下面的 ...

  4. 浮动,定位,flex布局

    什么是文档流 英文原文是:Normal flow. In CSS 2.1, normal flow includes block formatting of block-level boxes, in ...

  5. CSS引入的方式有哪些? link和@import的区别是?

    CSS引入的方式包括内联 内嵌 外链 导入 link和@import的区别是 : ①link属于XHTML标签,除了加载CSS外,还能 用于定义RSS, 定义rel连接属性等作用:而@import是C ...

  6. [转载] linux下tar命令解压到指定的目录

    参考 http://blog.sina.com.cn/s/blog_62449fcf0100nfar.html linux下tar命令解压到指定的目录 :   #tar zxvf /bbs.tar.z ...

  7. 2001年NOIP普及组复赛题解

    题目涉及算法: 数的计算:动态规划: 最大公约数和最小公倍数问题:质因数分解: 求先序排列:递归: 装箱问题:动态规划(纯0-1背包问题) 数的计算 题目链接:https://www.luogu.or ...

  8. tp5 select出来数据集(对象)转成数组

    1.先在数据库配置文件中 //数据集返回类型 'resultset_type' => 'collection', 2.在使用时, 使用 toArray() 方法 //查询数据库 $news = ...

  9. 百度小程序富文本bdParse遇到的坑

    百度开发工具能正常显示文章图文详情, web浏览也可以, app浏览就不行, 审核说兼容性问题, 都不是, 后来发现是后台传输的数据问题, 不能用json_encode()返回数据

  10. pycharm下的多个python版本共存(一)

    经历过IDLE,anaconda,和pycharn的编程环境,并进行了一段时间的项目编程后,决定使用pycharm作为以后的工作环境. 一方面因为项目组其他人推荐,另一方面在使用过程中比较顺手.当然很 ...