P3299 [SDOI2013]保护出题人

题目描述

出题人铭铭认为给SDOI2012出题太可怕了,因为总要被骂,于是他又给SDOI2013出题了。

参加SDOI2012的小朋友们释放出大量的僵尸,企图攻击铭铭的家。而你作为SDOI2013的参赛者,你需要保护出题人铭铭。

僵尸从唯一一条笔直道路接近,你们需要在铭铭的房门前放置植物攻击僵尸,避免僵尸碰到房子。

第一关,一只血量为\(a_1\)点的墦尸从距离房子\(x_1\)米处速接近,你们放置了攻击力为\(y_1\)点/秒的植物进行防御;第二关,在上一关基础上,僵尸队列排头增加一只血量为\(a_2\)点的僵尸,与后一只僵尸距离\(d\)米,从距离房\(x_2\)米处匀速接近,你们重新放置攻击力为\(y_2\)点/秒的植物;……;第\(n\)关,僵尸队列共有\(n\)只僵尸,相邻两只僵尸距离\(d\)米,排头僵尸血量为\(a_n\)点,排第二的 僵尸血量\(a_{n-1}\),以此类推,排头僵尸从距离房子\(x_n\)米处匀速接近,其余僵尸跟随排头同时接近,你们重新放置攻击力为\(y_n\)点/秒的植物。

每只僵尸直线移动速度均为\(1\)米/秒,由于植物射击速度远大于僵尸移动速度,可忽略植物子弹在空中的时间。所有僵尸同时出现并接近,因此当一只僵尸死亡后,下一只僵尸立刻开始受到植物子弹的伤害。

游戏得分取决于你们放置的植物攻击力的总和\(\sum \limits _{i=1} ^{n} y_i\),和越小分数越高,为了追求分数上界,你们每关都要放置攻击力尽量小的植物。

作为SDOI2013的参赛选手,你们能保护出题人么?

输入输出格式

输入格式:

第一行两个空格隔开的正整数\(n\)和\(d\),分别表示关数和相邻僵尸间的距离。

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

输出格式:

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

说明

对于\(100\%\)的数据, \(1\le n\le 10^5,1\le d\le 10^{12},1\le x\le 10^{12},1\le a\le10^{12}\)


我自己只有一个naive的想法

整体二分,然后对在里面搞凸包弄一弄,感觉是可以做的,但是懒得写。

正解

设\(n\)个僵尸的前缀血量和为\(hp_i\),第\(i\)个僵尸为开头时距离房间为\(X_i\)

\[\sum_{p=1}^n\max_{i=1}^p\frac{hp_p-hp_{i-1}}{X_p+p\times d-i\times d}
\]

然后对前\(i\)个僵尸组成的波,维护点集\((i\times d,hp_i-1)\)的一个凸壳

然后每次询问\((hp_p,X_i+p\times d)\)与凸壳上一个点的最大斜率,直接三分就可以了

关于整数域上的三分,和二分一样写其实就可以,而且更快


Code:

#include <cstdio>
#include <algorithm>
const int N=1e5+10;
#define mp(a,b) std::make_pair(a,b)
std::pair <double,double> yuu[N];
int s[N],tot,n;
double hp[N];
double slope(int a,int b)
{
return (yuu[b].second-yuu[a].second)/(yuu[b].first-yuu[a].first);
}
void ins(double x,double y)
{
yuu[++n]=mp(x,y);
while(tot>1&&slope(n,s[tot])<slope(s[tot],s[tot-1])) --tot;
s[++tot]=n;
}
double qry(double x,double y)
{
int l=1,r=tot;
yuu[0]=mp(x,y);
while(l<r)
{
int mid=l+r>>1;
if(slope(0,s[mid])<slope(0,s[mid+1])) l=mid+1;
else r=mid;
}
return slope(0,s[l]);
}
int main()
{
int n;double d,ans=0;
scanf("%d%lf",&n,&d);
for(int i=1;i<=n;i++)
{
double a,x;
scanf("%lf%lf",&a,&x);
hp[i]=hp[i-1]+a;
ins(i*d,hp[i-1]);
ans+=qry(x+i*d,hp[i]);
}
printf("%.0f\n",ans);
return 0;
}

2019.2.14

洛谷 P3299 [SDOI2013]保护出题人 解题报告的更多相关文章

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

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

  2. P3299 [SDOI2013]保护出题人

    传送门 全世界都会二分可海星-- 首先记\(sum[i]\)为\(a[i]\)的前缀和,那么第\(i\)个的答案就是\(max\{\frac{sum[i]-sum[j-1]}{x+(i-j)d}\}\ ...

  3. 【BZOJ3203】[Sdoi2013]保护出题人 二分+凸包

    [BZOJ3203][Sdoi2013]保护出题人 Description Input 第一行两个空格隔开的正整数n和d,分别表示关数和相邻僵尸间的距离.接下来n行每行两个空格隔开的正整数,第i + ...

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

    [BZOJ3203] [SDOI2013]保护出题人(二分+凸包) 题面 题面较长,略 分析 对于第i关,我们算出能够打死前k个个僵尸的最小能力值,再取最大值就可以得到\(y_i\). 前j-1个僵尸 ...

  5. [SDOI2013]保护出题人

    题目 出题人铭铭认为给SDOI2012出题太可怕了,因为总要被骂,于是他又给SDOI2013出题了. 参加SDOI2012的小朋友们释放出大量的僵尸,企图攻击铭铭的家.而你作为SDOI2013的参赛者 ...

  6. BZOJ 3203 [SDOI2013]保护出题人 (凸包+三分)

    洛谷传送门 题目大意:太长略 每新加入一个僵尸,容易得到方程$ans[i]=max{\frac{sum_{i}-sum_{j-1}}{s_{i}+d(i-j)}}$ 即从头开始每一段僵尸都需要在规定距 ...

  7. 洛谷 P2323 [HNOI2006]公路修建问题 解题报告

    P2323 [HNOI2006]公路修建问题 题目描述 输入输出格式 输入格式: 在实际评测时,将只会有m-1行公路 输出格式: 思路: 二分答案 然后把每条能加的大边都加上,然后加小边 但在洛谷的题 ...

  8. 【洛谷 P3299】 [SDOI2013]保护出题人 (凸包,三分,斜率优化)

    题目链接 易得第\(i\)关的最小攻击力为\(\max_{j=1}^i\frac{sum[i]-sum[j-1]}{x+d*(i-j)}\) 十分像一个斜率式,于是看作一个点\(P(x+d*i,sum ...

  9. [bzoj3203][Sdoi2013]保护出题人

    人生第一道三分?... 把进攻序列里的前i只僵尸看成一个点,横坐标是第i只僵尸到达的时间,纵坐标是这i只僵尸的血量总和..就是说植物必须在这段时间内输出这些伤害..那么单位时间的输出伤害就是斜率了. ...

随机推荐

  1. Perhaps you are running on a JRE rather than a JDK

    在Eclipse中跑maven项目时,出现上面的问题: 1.有可能你的环境变量配置是在jre上面的,所以你要检查一下你配置文件,PATH和CLASSPATH都要检查 2.eclipse默认是跑在jre ...

  2. 【DDD】使用领域驱动设计思想实现业务系统

    最近新接了一个业务系统——社区服务系统,为了快速熟悉和梳理老系统的业务逻辑和代码,同时对老系统代码做一些优化,于是打算花上一个月时间不间断地对老系统服务进行重构.同时,考虑到社区业务的复杂性,想起了之 ...

  3. 小程序encryptedData

    准备知识: Base64编解码 AES算法.填充模式.偏移向量 session_key会话密钥,以及怎么存储和获取 以上3点对于理解解密流程非常重要. 根据官方文档,我梳理了大致的解密流程,如下: 小 ...

  4. Popush End

    coconut: (咳咳)作为一名后台开发者,我觉得自己在这次作业完成中最大的收获就是跟node.js的异步模型打交道.首先我得出了一个这样的结论:异步模型能够提高服务器的高性能并发请求,但是却加大了 ...

  5. Linux内核期末总结

    20135316王剑桥<Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC 1000029000 第一周 http://www.cn ...

  6. IT行业的创新的读后感

    一.什么是创新 创新是以新思维.新发明和新描述为特征的一种概念化过程.它原意有三层含义,第一,更新:第二,创造新的东西:第三,改变.创新是人类特有的认识能力和实践能力,是人类主观能动性的高级表现形式, ...

  7. back

    #include<stdio.h>   int main()   {   int a[5],b[5][5];   int i,j,sum,max,m,n;   printf("输 ...

  8. navicat有数据额结构同步

    这个功能可能检查两个库的表结构异同,进行表结构构同步,可以生成同步语句. 比如在测试环境表中新增了字段,可以通过这个工具进行表结构同步.

  9. ppm\℃是什么意思/

    转自http://www.zybang.com/question/b158a106b4e39d8fdb2b93fd3777a00f.html 在基准电压的数据手册里,我们会找到一个描述基准性能的直流参 ...

  10. MySQL基础知识——范式与事务

    几个概念 在说范式之前,要先了解几个概念: 关系模式 关系模式的5要素:R(U,D,DOM,F) 用下面这个category表来理解上面这个式子 mysql> desc student; +-- ...