3203: [Sdoi2013]保护出题人

Time Limit: 3 Sec Memory Limit: 128 MB
Submit: 389 Solved: 218
[Submit][Status][Discuss]
Description

Input

第一行两个空格隔开的正整数n和d,分别表示关数和相邻僵尸间的距离。接下来n行每行两个空格隔开的正整数,第i + 1行为Ai和 Xi,分别表示相比上一关在僵尸队列排头增加血量为Ai 点的僵尸,排头僵尸从距离房子Xi米处开始接近。

Output

一个数,n关植物攻击力的最小总和 ,保留到整数。

Sample Input

5 2

3 3

1 1

10 8

4 8

2 3

Sample Output

7
HINT

第一关:距离房子3米处有一只血量3点的僵尸,植物最小攻击力为1.00000; 第二关:距离房子1米处有一只血量1点的僵尸、3米处有血量3点的僵尸,植物最小攻击力为1.33333; 第三关:距离房子8米处有一只血量10点的僵尸、10米处有血量1点的僵尸、12米处有血量3点的僵尸,植物最小攻击力为1.25000; 第四关:距离房子8米处有一只血量4点的僵尸、10米处有血量10点的僵尸、12米处有血量1点的僵尸、14米处有血量3点的僵尸,植物最小攻击力为1.40000; 第五关:距离房子3米处有一只血量2点的僵尸、5米处有血量4点的僵尸、7米处有 血量10点的僵尸、9米处有血量1点的僵尸、11米处有血量3点的僵尸,植物最小攻击力 为2.28571。 植物攻击力的最小总和为7.26905。

对于100%的数据, 1≤n≤10^5,1≤d≤10^12,1≤x≤ 10^12,1≤a≤10^12

感觉这道题还是比较好的。
首先对于第i关来说,对应的yi应该怎样求呢??
题目中说一个僵尸死了之后,植物会接着攻击后一个僵尸而且僵尸的移动速度是一样的,也就是只有打死了之前的所有僵尸,才能打到最后一个僵尸。这样我们就可以把之前所有僵尸的血全部放到最后一个身上,再除以最后一个到终点的距离,就是速度。
可是这样不能保证前面的僵尸在被打死之前就吃到了植物。所以我们需要将i之前的全部都处理一遍。
yi=max{(sum[i]-sum[j-1])/(x[i]+(i-j)*d)} 1<=j<=i
这样我们处理出了每一关的y。
这样每次做都是n^2的。我们观察一下上面的式子,发现这是个斜率的形式,因为k=(y1-y2)/(x1-x2)。
所以我们设x1=x[i]+i * d,x2=j * d,y1=sum[i],y2=sum[j-1]。
这样就变成了一个球斜率的最大值。
我们维护一个下凸包,每次新加入一个点的时候,因为上面的那个函数是个单峰的,所以在凸包上面三分就行了。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define eps 1e-6
#define LL long long
#define mid1 l+(r-l)/3
#define mid2 l+(r-l)/3*2
const int N=100010;
int n,siz;
double ans,d,sum[N],xi[N];
struct Point{double x,y;}q[N];
Point operator - (Point x,Point y){return (Point){x.x-y.x,x.y-y.y};}
inline double Cross(Point x,Point y){return x.x*y.y-x.y*y.x;}
inline double calc(Point x){int l=1,r=siz,i;double maxn=0,k1,k2;while(l+2<r){k1=(x.y-q[mid1].y)/(x.x-q[mid1].x);k2=(x.y-q[mid2].y)/(x.x-q[mid2].x); maxn=max(maxn,max(k1,k2));if(k1<k2) l=mid1;else r=mid2;}for(i=l;i<=r;++i) maxn=max(maxn,(x.y-q[i].y)/(x.x-q[i].x));return maxn;
}
int main(){int i,j;scanf("%d%lfd",&n,&d);for(i=1;i<=n;++i){scanf("%lf%lf",&sum[i],&xi[i]);sum[i]+=sum[i-1];}ans=sum[1]/xi[1];q[siz=1]=(Point){d,sum[0]};for(i=2;i<=n;++i){Point x=(Point){i*d,sum[i-1]};while(siz>=2&&Cross(q[siz]-q[siz-1],x-q[siz-1])<=0) --siz;q[++siz]=x;x=(Point){xi[i]+i*d,sum[i]};ans+=calc(x);}printf("%.0f\n",ans);
}

[bzoj3203][SDOI2013]保护出题人相关推荐

  1. [BZOJ3203][SDOI2013]保护出题人(凸包+三分)

    https://www.cnblogs.com/Skyminer/p/6435544.html 先不要急于转化成几何模型,先把式子化到底再对应到几何图形中去. 1 #include<cstdio ...

  2. bzoj3203: [Sdoi2013]保护出题人

    我三分这么好吗居然1A啦???提交的时候只是想着先WA一次的.... 这题真的很妙啊 首先第一步,就是把僵尸的生命值取一个前缀和,这样造成伤害的时候,可以视为同时对所有僵尸造成伤害. 那么就可以得到一 ...

  3. bzoj3203 [Sdoi2013]保护出题人 凸包+二分

    一开始以为丧尸可以挡伤害,然后发现这个题目的设定非常** 然后就考虑每个丧尸到门口的时间,由于伤害是继承的,所以前缀和分配 然后答案=Σ(HP前缀和*速度/距离)  设 HP/l=k ,l=x+nd ...

  4. BZOJ 3203 Luogu P3299 [SDOI2013]保护出题人 (凸包、斜率优化、二分)

    惊了,我怎么这么菜啊.. 题目链接: (bzoj)https://www.lydsy.com/JudgeOnline/problem.php?id=3203 (luogu)https://www.lu ...

  5. BZOJ 3203 Sdoi2013 保护出题人 凸包+三分

    题目大意:太长自己看 令sumi表示第i个僵尸以及之前的僵尸的体力总和.disi表示第i个僵尸与房屋的初始距离 我们发现我们能消灭一个僵尸当且仅当y>=sumidisi 那么我们要求的显然就是m ...

  6. [选拔赛1]花园(矩阵快速幂),JM的月亮神树(最短路),保护出题人(斜率优化)

    多年不考试,一夜回到解放前 T1:花园 title solution code T2:月亮神树 title solution code T3:保护出题人 title solution code T1: ...

  7. BZOJ 3203 sdoi 2013 保护出题人

    由于样例解释很清晰,所以很容易得到以下结论: 1.每一关都是独立的,且僵尸的相对位置不会变 2.每一关的攻击力=Max(sum(i)/dis(i)) 其实sum(i)是僵尸攻击力的前缀和,dis(i) ...

  8. BAT华为美团头条面试考什么?这份GitHub万星资源,告诉你面试题+答案+出题人分析...

    铜灵 发自 凹非寺 量子位 出品 | 公众号 QbitAI 2020校招脚步临近,怎样备战即将到来的面试,在众多面试者中脱颖而出惊艳到面试官,化身大厂Offer收割机? GitHub上就有这样一个万星 ...

  9. 牛客练习赛38 E 出题人的数组 2018ccpc桂林A题 贪心

    https://ac.nowcoder.com/acm/contest/358/E 题意: 出题人有两个数组,A,B,请你把两个数组归并起来使得cost=∑i∗ci 最小,归并要求原数组的数的顺序在新 ...

最新文章

  1. Survey | 深度学习方法在生物网络中的应用
  2. 【每天学一点linux】后台进程不打印日志
  3. 创建 3D 控件_2.设置角色蓝图
  4. deepin v20.4设置全局搜索的快捷键
  5. JavaScript | 创建对象并通过JavaScript函数在表中显示其内容
  6. 9.6 LSMW程序删除操作手册-录屏
  7. 【C++】位运算实现加减乘除
  8. web前端开发是干嘛的?
  9. 运行文件服务器,服务器的运行目录文件
  10. 忘了微信密码怎么办_微信支付密码怎么改?微信支付密码忘了怎么办?详细教程来了!...
  11. Vim插件(三) Terminal 终端
  12. 一元线性回归模型系数、方差估计、检验回归效果显著性,b的置信区间,Y约为X的指数函数时,求Y关于x的回归方程
  13. 二十道面试题成都至少16k
  14. web前端人员培训要学些什么?
  15. 树莓派新手使用iobroker日志三(米家全家桶加入iobroker)
  16. 当地图遇到微博,生活其实可以这么玩
  17. C# iTextSharp 创建PDF水印
  18. 基于svg.js实现可编辑的图像(1)
  19. 对标阿里P5—P8Java社招岗的面试题解析
  20. 私有云 解决方案_私有云–理想的业务解决方案

热门文章

  1. CVPR 2017论文集锦(论文分类)—— 附录部分翻译
  2. mysql一个字符占用多少个字节
  3. Java面向对象高阶
  4. oracle的faq,ORACLE之常用FAQ V1.0
  5. 遭红杉资本沈南鹏​抛售650万股后,美团仍面临重大风险
  6. Mycat快速入门(一): Mycat简介
  7. 【目标检测无痛涨点篇】SWA:平均多个模型权值
  8. 让bug无处藏身,Java 线上问题排查神器,你学废了吗?
  9. 国内chatGPT镜像
  10. Ardupilot 串口代码学习