码迷,mamicode.com
首页 > 其他好文 > 详细

CF1293B - JOE is on TV! DP 序列DP 单调性优化

时间:2020-02-07 11:13:21      阅读:75      评论:0      收藏:0      [点我收藏+]

标签:break   pac   bre   main   序列   不难   scan   clu   ace   

如果f[x]表示有x个对手时候的最大获益。不难看出f[x] = max(f[i] + 1 - i / x)。i表示这次答题后剩下几个队首。

不难看出,随着x的增加,最大转移的i也是单调的,然后单调性优化下就可以了。

 1 #include <cstdio>
 2 using namespace std;
 3 int n,l;
 4 double f[110000];
 5 double getval(int x,int y)
 6 {
 7     return (x * f[y] + x - y) / x;
 8 }
 9 int main()
10 {
11     scanf("%d",&n);
12     f[0] = 0.0;
13     l = 0; 
14     for (int i = 1;i <= n;i++)
15         for (;l < i;l++)
16         {
17             if (getval(i,l) > getval(i,l + 1))
18             {
19                 f[i] = getval(i,l);
20                 break;
21             }
22         }
23     printf("%.6lf\n",f[n]);
24     return 0;
25 }

 

CF1293B - JOE is on TV! DP 序列DP 单调性优化

标签:break   pac   bre   main   序列   不难   scan   clu   ace   

原文地址:https://www.cnblogs.com/iat14/p/12272027.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!