【题解】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. jmeter循环取消今天所有的订单

    结构 1.首先,添加JDBC Connection Configuration 2.其次添加JDBC request 添加循环控制器 循环控制器下方添加计数器 ${__V(reservationID_ ...

  2. Python错误:AttributeError: 'generator' object has no attribute 'next'解决办法

    今天在学习生成器对象(generation object)运行以下代码时,遇到了一个错误: #定义生成器函数def liebiao(): for x in range(10): yield x#函数调 ...

  3. behavior planning——inputs to transition functions

    the answer is that we have to pass all  of the data into transition function except for the previous ...

  4. 【DCN】Wireless Intranet Captive Portal

    Wireless Intranet Captive Portal 配置AAA服务Radius认证 radius-server key 0 radius radius-server authentica ...

  5. origin/HEAD -> origin/master 这个分支是干嘛的啊

    ➜ sso git:(master) ✗ git branch -r origin/4.0 origin/HEAD -> origin/master origin/master origin/H ...

  6. 微信小程序下拉刷新 并重新加载数据

    1.在json页面配置: { "enablePullDownRefresh": true } 2.调用刷新函数 onPullDownRefresh: function() { wx ...

  7. axis2 wsdl2java工具

    wsdl2java工具使用方法描述: C:\Users\Administrator>wsdl2java -h Using AXIS2_HOME: E:\Apache_Projects\axis2 ...

  8. 2018-2-13-C#-枚举转字符串

    title author date CreateTime categories C# 枚举转字符串 lindexi 2018-2-13 17:23:3 +0800 2018-2-13 17:23:3 ...

  9. 高可用之nginx配置文件详解

    #user nobody; worker_processes 1;##工作线程数,一般和cpu的核数相同:可通过ps -ef | nginx查看线程数 #配置错误日志位置 #error_log log ...

  10. [转]分布式监控工具Ganglia 介绍 与 集群部署.

    如果你目的很明确就是冲着标题来的,不爱看我唠叨,请直接进入第二个分割线之后的内容. 其实之前就是有做Swift监控平台的打算的,但是因为没什么硬性需求么,也不要紧的,就一直搁置了.最近实验室来了个大二 ...