[Bzoj4570][Scoi2016]妖怪(右上凸包)
4570: [Scoi2016]妖怪
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 1110 Solved: 336
[Submit][Status][Discuss]
Description
Input
Output
输出在最不利情况下最强妖怪的战斗力值,保留4位小数。
Sample Input
Sample Output
8.0000
分析
虽然是看了别人的博客才写起的,但也要写博客加深印象。

发现是L是一条斜率-b/a的直线。
如果已知直线L,在它下最强的妖怪是谁呢?
那么画图来试试,一大堆小点点是一个妖怪,然后右上角是维护的右上凸包

发现粉色直线与右上凸包的切点是在它下的最强妖怪
为什么是右上凸包与它切点最优,因为我们答案是横纵截距之和,我们把直线往下平移发现横纵截距都在减小,肯定不会比切点的战斗力小
已知右上凸包怎么对右上凸包每个点求出一个最优的斜率k使它为切点?
可以得出结论:斜率一定是大于它与上一个点连线的斜率,小于它与下一个点连线的斜率
设右上凸包每一个点与下一个点连线斜率为ki
那么斜率k就在这个范围内
,我们要在这个范围内求一个点使答案最小。
当我们已知点(x,y)求L时,x,y变成了常数,又斜率k为-b/a
那么答案可以表示为
发现是个双钩函数,在k = -(x/y)^½时取最小。
因为是双钩函数不满足单调,我就去三分了,然后华丽丽T了。
其实我们可以判断一下双钩函数顶点是否在合法范围内,是的话取最小值
不是的话肯定是关于双钩函数的一边,则具有单调性。
那么此时我就想到二分了。。。然后完美地t了
正解:
合法范围ki-1和ki一定是双钩函数定义域的端点。每个点可以用ki算一次答案,如果顶点在定义域内还可以算一次答案
AC代码:
# include <iostream>
# include <cstdio>
# include <cstring>
# include <cmath>
# include <algorithm>
using namespace std;
const int N = 1e6 + ;
const double eps = 1e-;
const double inf = 0x3f3f3f3f;
struct Point{
double x,y;
Point(){}
Point(double a,double b) : x(a),y(b){}
void read(){scanf("%lf %lf",&x,&y);}
double com(){return x + y + * sqrt(x * y);}
bool operator <(const Point & other)const{return x == other.x ? y > other.y : x > other.x;}
}a[N];
int n,ed;double k[N],ans = inf;
Point operator -(Point a,Point b){return Point(a.x - b.x,a.y - b.y);}
double Get(Point a){return a.y / a.x;}
double Cross(Point a,Point b){return a.x * b.y - a.y * b.x;}
int main()
{
scanf("%d",&n);
for(int i = ;i <= n;i++)a[i].read();
sort(a + ,a + n + );int top = ;
for(int i = ;i <= n;i++)
{
while(top > && Cross(a[i] - a[top],a[top] - a[top - ]) >= )top--;
a[++top] = a[i];
}
a[top + ] = Point(,);
for(int i = ;i <= top;i++)
{
k[i] = Get(a[i + ] - a[i]);
ed = i;if(k[i] >= )break;
}
k[ed] = -eps;k[] = -inf;
for(int i = ;i <= ed;i++)
{
double mk = -sqrt(a[i].y / a[i].x),cg = inf,he;
if(mk > k[i - ] && mk < k[i])cg = a[i].com();
he = a[i].x + a[i].y - a[i].x * k[i] - a[i].y / k[i];
cg = cg > he ?
he : cg;ans = ans > cg ? cg : ans;
}
printf("%.4lf\n",ans);
}
[Bzoj4570][Scoi2016]妖怪(右上凸包)的更多相关文章
- 2018.10.15 bzoj4570: [Scoi2016]妖怪(凸包)
传送门 不得不说这题有点东西啊. 看到题第一眼二分,用二次函数求范围来进行checkcheckcheck,20分滚粗了233. 于是开始思考正解. 发现可以把每只怪物的二元组属性看成二维坐标. 这时对 ...
- BZOJ4570: [Scoi2016]妖怪
题目传送门 4570: [Scoi2016]妖怪 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 491 Solved: 125 [Submit][Sta ...
- [BZOJ4570][SCOI2016]妖怪(凸包)
两种做法,前一种会TLE. 第一种是高一数学题做法,设一个妖怪的atk和dnf分别为x和y,则它在(a,b)环境下的战斗力为x+y/a*b+y+x/a*b. 设t为b/a,则战斗力即$f(x,y,t) ...
- BZOJ4570 SCOI2016妖怪(三分)
strength=atk*(1+b/a)+dnf*(1+a/b).设a/b=x,可以发现这是一个关于x的对勾函数.开口向上的一堆凸函数取max还是凸函数,三分即可. 然而无良出题人既卡精度又卡时间.众 ...
- BZOJ 4570: [Scoi2016]妖怪
二次联通门 : BZOJ 4570: [Scoi2016]妖怪 二次联通门 : luogu P3291 [SCOI2016]妖怪 LibreOJ : LibreOJ #2015. 「SCOI2016 ...
- 【bzoj4570 scoi2016】妖怪
题目描述 邱老师是妖怪爱好者,他有n只妖怪,每只妖怪有攻击力atk和防御力dnf两种属性.邱老师立志成为妖怪大师,于是他从真新镇出发,踏上未知的旅途,见识不同的风景. 环境对妖怪的战斗力有很大影响,在 ...
- LOJ#2015. 「SCOI2016」妖怪(凸包)
传送门 首先可以把每个妖怪看成二维平面上的一个点,那么每一个环境\((a,b)\)就可以看成一条斜率\(k=-\frac{b}{a}\)的过该点的直线,战斗力就是这条直线在两坐标轴上的截距之和 对于每 ...
- BZOJ4570:[SCOI2016]妖怪——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4570 邱老师是妖怪爱好者,他有n只妖怪,每只妖怪有攻击力atk和防御力dnf两种属性.邱老师立志成 ...
- 【BZOJ4570】 [Scoi2016]妖怪
Description 邱老师是妖怪爱好者,他有n只妖怪,每只妖怪有攻击力atk和防御力dnf两种属性.邱老师立志成为妖怪大师,于 是他从真新镇出发,踏上未知的旅途,见识不同的风景.环境对妖怪的战斗力 ...
随机推荐
- IOS状态栏
IOS状态栏是什么地方? 它是IOS设备屏幕顶部显示信号以及电池的区域.状态栏默认的高度是20像素,状态栏在软件开发中有何作用?联网应用中可在自动帮用户下载数据时使用,推荐在状态栏中予以显示.状态栏可 ...
- Traceroute侦测主机到目的主机之间所经路由情况的重要工具
ICMP的应用--Traceroute Traceroute是用来侦测主机到目的主机之间所经路由情况的重要工具,也是最便利的工具.前面说到,尽管ping工具也可以进行侦测,但是,因为ip头的限制,pi ...
- 分类IP地址(A、B、C类)的指派范围、一般不使用的特殊IP地址
分类IP地址(A.B.C类)的指派范围.一般不使用的特殊IP地址 A类地址:0开头,8位网络号 B类地址:10开头,16位网络号 C类地址:110开头,24位网络号 D类地址:1110开头,多播地址 ...
- Java代理模式精讲之静态代理,动态代理,CGLib代理
代理(Proxy)是一种设计模式,通俗的讲就是通过别人达到自己不可告人的目的(玩笑). 如图: 代理模式的关键点是:代理对象与目标对象.代理对象是对目标对象的扩展,并会调用目标对象 这三个代理模式,就 ...
- selective_search_rcnn.m中代码
im = imresize(im, [NaN im_width]):把图像转换为宽度为im_width,自动计算列数
- linux 搜索文本
find -type f -name '*.php'|xargs grep '127.0.0.1' 搜索所有.php 内容 127.0.0.1 转自:http://www.cnblogs.com/w ...
- 888. Fair Candy Swap@python
Alice and Bob have candy bars of different sizes: A[i] is the size of the i-th bar of candy that Ali ...
- python基础(二) —— 流程控制语句
编程语言中的流程控制语句分为以下几类: 顺序语句 分支语句 循环语句 其中顺序语句不需要单独的关键字来控制,就是按照先后顺序一行一行的执行,不需要特殊的说明. 下面主要是 分支语句 和 循环语句的说明 ...
- (8) tomcat中管理领域、角色及用户
srverlet Container或web应用程序本身都可以提供控制web应用程序资源的安全防护 前者称为容器管理的安全防护,或者称为应用程序管理安全防护 通过内嵌机制,tomcat提供一些安全防护 ...
- 第二天,学习if,变量,注释
zz_age = 31guss_age=int(input("input your answer:"))if guss_age == zz_age: print ("Yo ...