CF1067D Computer Game
题意:
有 n 道题,每个题可以做很多次但只能领悟一次,一开没有领悟任何题。
对于第 i 个题,正确率为 $p_i$ 。领悟之前,做对这个题可以提升 $a_i$ 的能力值;领悟之后,做对这个题可以提升 $b_i$ 的能力值。(保证 $a_i<b_i$ )
做对一个题,还可以领悟任意一个题(任选)。做错题后,什么都不会发生。
现在可以做 t 次题(同一题算多次),问最大能力值? $n\leq 10^5,t\leq 10^{10}$
题解:
【一些吐槽】 由于考试数据水现场各种水过。大家都猜了一个错误的结论:领悟之前和之后都各只做一道题。
事实上领悟之后确实是只做一道题,选的一定是 $b_ip_i$ 最大的那个题,记这个值为 $mx$ ,但领悟之前就不是了,需要 dp 。
设 $f_t$ 表示 t 时刻的最大能力值,方程$$\begin{aligned}f_{t+1}&=\max \{p_i\times (a_i+mx\times t)+(1-p_i)\times f_t\}\\f_{t+1}&=\max \{p_ia_i+p_i\times(mx\times t-f_t)\}+f_t\end{aligned}$$
这里有个性质:由于一轮的贡献不会超过 mx ,所以有$$\begin{aligned}f_{t+1}-f_t &\leq mx \\ \Longleftrightarrow t\times mx-f_t &\leq (t+1)\times mx-f_{t+1}\end{aligned}$$
即 $mx\times t-f_t$ 是单调不减的。
那么把 $p_ia_i$ 看成截距, $p_i$ 看成斜率, $f$ 的转移就相当于取若干一次函数的最大值,求下凸壳即可。 dp 的时候从左往右扫每条直线,用矩阵乘法和倍增优化转移。复杂度 $\mathcal{O}(n\log T)$ 。
code:
#include<bits/stdc++.h>
#define rep(i,x,y) for (int i=(x);i<=(y);i++)
#define ll long long
#define db double using namespace std; const int N=1e5+;
int n,m; db mx,ans; ll t,cnt; const db eps=1e-;
const int dcmp(db x){return fabs(x)<eps?:x<-eps?-:;} struct line{
db k,b;
line(db k=,db b=):k(k),b(b){}
friend bool operator < (line x,line y){
return dcmp(x.k-y.k)==?dcmp(x.b-y.b)>:dcmp(x.k-y.k)<;
}
}p[N],q[N]; struct mat{
int n,m; db a[][];
mat(int n=,int m=):n(n),m(m){memset(a,,sizeof(a));}
friend mat operator * (mat x,mat y){
mat z(x.n,y.m);
rep (i,,z.n-)
rep (j,,z.m-)
rep (k,,x.m-) z.a[i][j]+=x.a[i][k]*y.a[k][j];
return z;
}
}A,B,trs[]; db inter_x(line x,line y){return (y.b-x.b)/(x.k-y.k);} int main(){
scanf("%d%lld",&n,&t);
rep (i,,n){
int a,b; db c;
scanf("%d%d%lf",&a,&b,&c);
mx=max(mx,b*c),p[i]=line(c,a*c);
}
sort(p+,p++n);
rep (i,,n) if (i==||dcmp(p[i].k-p[i-].k)!=) q[++m]=p[i];
n=;
rep (i,,m){
while (n>=&&dcmp(inter_x(q[i],p[n])-inter_x(p[n],p[n-]))<=) n--;
p[++n]=q[i];
}
cnt=;
A=mat(,); A.a[][]=;
for (int i=;i<=n&&cnt<t;i++){
db R=mx*cnt-A.a[][];
while (i<n&&dcmp(inter_x(p[i],p[i+])-R)<=) i++;
if (i<n) R=inter_x(p[i],p[i+]);
trs[]=mat(,);
trs[].a[][]=-p[i].k,trs[].a[][]=p[i].k*mx,trs[].a[][]=p[i].b;
trs[].a[][]=trs[].a[][]=trs[].a[][]=;
rep (j,,) trs[j]=trs[j-]*trs[j-];
for (int j=;~j;j--)
if (cnt+(1ll<<j)<t){
B=trs[j]*A;
if (i==n||dcmp((cnt+(1ll<<j))*mx-B.a[][]-R)<=) A=B,cnt+=1ll<<j;
}
cnt++,A=trs[]*A;
}
printf("%.10lf\n",A.a[][]);
return ;
}
CF1067D Computer Game的更多相关文章
- [CF1067D]Computer Game[凸包/斜率优化+倍增+矩阵乘法]
题意 你有 \(n\) 个任务,初始收益为 \(a\) ,共 \(t\) 轮游戏,每轮可以选择完成一个任务(可以做多次),完成之后可以给任意任务升级,升级之后的任务收益为 \(b\) ,每个任务还有完 ...
- CF1067D. Computer Game(斜率优化+倍增+矩阵乘法)
题目链接 https://codeforces.com/contest/1067/problem/D 题解 首先,如果我们获得了一次升级机会,我们一定希望升级 \(b_i \times p_i\) 最 ...
- 共享文件夹:The user has not been granted the requested logon type at this computer
场景重现 今天做一个项目测试,要用到虚拟机,于是在虚拟机(XP 32)上新建了一个共享的文件夹.然后我在Win7 机器上访问它得到如下的error 消息:
- Computer assisted surgery
Computer assisted surgery (CAS) represents a surgical concept and set of methods, that use computer ...
- Computer vision labs
积累记录一些视觉实验室,方便查找 1. 多伦多大学计算机科学系 2. 普林斯顿大学计算机视觉和机器人实验室 3. 牛津大学Torr Vision Group 4. 伯克利视觉和学习中心 Pro ...
- Computer Vision: OpenCV, Feature Tracking, and Beyond--From <<Make Things See>> by Greg
In the 1960s, the legendary Stanford artificial intelligence pioneer, John McCarthy, famously gave a ...
- 数论 - Vanya and Computer Game
Vanya and his friend Vova play a computer game where they need to destroy n monsters to pass a level ...
- A Taxonomy of Computer Organizations
COMPUTER OR GANIZATION AND ARCHITECTURE DESIGNING FOR PERFORMANCE NINTH EDITION
- [转载]Three Trending Computer Vision Research Areas, 从CVPR看接下来几年的CV的发展趋势
As I walked through the large poster-filled hall at CVPR 2013, I asked myself, “Quo vadis Computer V ...
随机推荐
- C# 获取文件图标
今天突然想到一个问题,如何去获取一个文件的关联图标呢?于是就上网搜索了一下.现总结如下: 首先明确问题:获取一个文件的关联图标或者是某个类型文件的显示图标. 在网上搜了一圈,发现方法还是比较多的,但是 ...
- 何凯文每日一句打卡||DAY4
- 蓝桥杯 算法训练 单词接龙 _DFS_搜索 字符串比较
单词接龙 问题描述 单词接龙是一个与我们经常玩的成语接龙相类似的游戏,现在我们已知一组单词,且给定一个开头的字母,要求出以这个字母开头的最长的“龙”(每个单词都最多在“龙”中出现两次),在两个单词相 ...
- [转载]Frontend Knowledge Structure
https://github.com/JacksonTian/fks http://code.csdn.net/news/2819224 本文为大家整理了一系列关于JavaScript的常用工具,包括 ...
- 使用sso(cas)的时候报单点登录service不匹配问题分析及解决
最近在使用portal做企业门户网站,其中使用了sso.在集成了多个应用之后在portal中点击集成的应用报错 2017-05-31 08:37:16,950 ERROR [org.jasig.cas ...
- HDU 2066 一个人的旅行 最短路问题
题目描述:输入的第一行有三个数,T,S,D,T表示一共有多少条线路,S表示起点的个数,D表示终点的个数,接下来就是输入T条路的信息了,要你判断从多个起点中任意一个到多个终点中的任意的一个的最短距离是多 ...
- [HNOI2013]比赛 (用Hash实现记忆化搜索)
[HNOI2013]比赛 题目描述 沫沫非常喜欢看足球赛,但因为沉迷于射箭游戏,错过了最近的一次足球联赛.此次联 赛共N支球队参加,比赛规则如下: (1) 每两支球队之间踢一场比赛. (2) 若平局, ...
- 数位dp(D - How Many Zeroes? LightOJ - 1140 )
题目链接:https://cn.vjudge.net/contest/278036#problem/D 题目大意:T组测试数据,每一次输入两个数,求的是在这个区间里面,有多少个0,比如说19203包括 ...
- 5 THINGS TOP BUG BOUNTY HUNTERS DO DIFFERENTLY
出处:https://www.hackerone.com/blog/5-things-top-bug-bounty-hunters-do-differently 本周,我们有幸收容了50名比利时科技学 ...
- 解决getJSON跨域登录Session丢失的问题
最近在做项目中发现,我用下面的代码异步请求到login.ashx: var memberUrl = rooturl + 'member.ashx?r=' + Math.random() + '& ...