刷题总结——射箭(bzoj2732)
题目:
Description
沫沫最近在玩一个二维的射箭游戏,如下图 1 所示,这个游戏中的 x 轴在地面,第一象限中有一些竖直线段作为靶子,任意两个靶子都没有公共部分,也不会接触坐标轴。沫沫控制一个位于(0,0)的弓箭手,可以朝 0 至 90?中的任意角度(不包括 0度和 90度),以任意大小的力量射出带有穿透能力的光之箭。由于游戏中没有空气阻力,并且光之箭没有箭身,箭的轨迹会是一条标准的抛物线,被轨迹穿过的所有靶子都认为被沫沫射中了,包括那些 只有端点被射中的靶子。这个游戏有多种模式,其中沫沫最喜欢的是闯关模式。在闯关模式中,第一关只有一个靶 子,射中这个靶子即可进入第二关,这时在第一关的基础上会出现另外一个靶子,若能够一箭 双雕射中这两个靶子便可进入第三关,这时会出现第三个靶子。依此类推,每过一关都会新出 现一个靶子,在第 K 关必须一箭射中前 K 关出现的所有 K 个靶子才能进入第 K+1 关,否则游戏 结束。沫沫花了很多时间在这个游戏上,却最多只能玩到第七关“七星连珠”,这让她非常困惑。 于是她设法获得了每一关出现的靶子的位置,想让你告诉她,最多能通过多少关
Input
输入文件第一行是一个正整数N,表示一共有N关。接下来有N行,第i+1行是用空格隔开的三个正整数xi,yi1,yi2(yi1<yi2 ),表示第i关出现的靶子的横坐标是xi,纵坐标的范围是从yi1到yi2 。
输入保证30%的数据满足N≤100,50%的数据满足N≤5000,100%的数据满足N≤100000且给 出的所有坐标不超过109 。
Output
Sample Input
2 8 12
5 4 5
3 8 10
6 2 3
1 3 7
Sample Output
HINT
题解
这里引用hzwer的题解,orz····链接:http://hzwer.com/5404.html
设抛物线y=ax^2+bx
则y1<=ax1^2+bx1<=y2
ax1^2+bx1>=y1
=>bx1>=y1-ax1^2
=>b>=y1/x1-ax1
这样得到一个关于a,b的不等式。。。
每一关都是俩不等式。。。这就变成了半平面交问题
二分答案k,判1-k的不等式半平面交是否为空
复杂度nlogn
心得:
半品面交两大模版题第二道···用于解多个ax+by>=(<=)b的不等式···,注意建边的时候用的是x=-1和x=1的两端点就行,但是···
md一个精度卡了我半个小时啊··艹
代码:
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<ctime>
#include<cctype>
#include<cstring>
#include<string>
#include<algorithm>
#define double long double
using namespace std;
int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
const int inf=1e9+;
const int N=;
struct point
{
double x;
double y;
};
struct line
{
point a;
point b;
double slope;
int id;
}l[N],q[N],a[N];
int n,tot,cnt,le,ri;
long long x,ya,yb;
int ans;
inline point operator-(point a,point b)
{
point t;
t.x=a.x-b.x;
t.y=a.y-b.y;
return t;
}
inline double operator*(point a,point b)
{
return a.x*b.y-a.y*b.x;
}
double cal(double x,double y,double a)
{
return y/x-a*x;
}
bool comp(line a,line b)
{
if(a.slope==b.slope)return (a.b-a.a)*(b.a-a.a)>;
return a.slope<b.slope;
}
point inter(line a,line b)
{
double k1,k2,t;
k1=(b.b-a.a)*(a.b-a.a);
k2=(a.b-a.a)*(b.a-a.a);
t=k2/(k1+k2);
point p;
p.x=b.a.x+t*(b.b.x-b.a.x);
p.y=b.a.y+t*(b.b.y-b.a.y);
return p;
}
bool jud(line a,line b,line c)
{
point t=inter(a,b);
return (t-c.a)*(c.b-c.a)>;
}
void build(int x)
{
tot=;
for(int i=;i<=cnt;i++)
if(l[i].id<=x)
{
if(l[i].slope!=a[tot].slope)tot++;
a[tot]=l[i];
}
le=,ri=;
q[++ri]=a[];
q[++ri]=a[];
for(int i=;i<=tot;i++)
{
while(le<ri&&jud(q[ri],q[ri-],a[i])) ri--;
while(le<ri&&jud(q[le],q[le+],a[i])) le++;
q[++ri]=a[i];
}
while(le<ri&&jud(q[ri],q[ri-],q[le])) ri--;
while(le<ri&&jud(q[le],q[le+],q[ri])) le++;
}
int main()
{
//freopen("a.in","r",stdin);
scanf("%d",&n);
l[++cnt].a=(point){-inf,inf},l[cnt].b=(point){-inf,-inf};
l[++cnt].a=(point){-inf,-inf},l[cnt].b=(point){inf,-inf};
l[++cnt].a=(point){inf,-inf},l[cnt].b=(point){inf,inf};
l[++cnt].a=(point){inf,inf},l[cnt].b=(point){-inf,inf};
for(int i=;i<=n;i++)
{
scanf("%lld",&x);
scanf("%lld",&ya);
scanf("%lld",&yb);
l[++cnt].a.x=-,l[cnt].a.y=cal(x,ya,-);
l[cnt].b.x=,l[cnt].b.y=cal(x,ya,);
l[++cnt].a.x=,l[cnt].a.y=cal(x,yb,);
l[cnt].b.x=-,l[cnt].b.y=cal(x,yb,-);
l[cnt].id=l[cnt-].id=i;
}
for(int i=;i<=cnt;i++)
l[i].slope=atan2(l[i].b.y-l[i].a.y,l[i].b.x-l[i].a.x);
sort(l+,l+cnt+,comp);
int L=,R=n;
while(L<=R)
{
int mid=(L+R)/;
build(mid);
if(ri-le+>=)
{
ans=mid;
L=mid+;
}
else
R=mid-;
}
printf("%d",ans);
return ;
}
刷题总结——射箭(bzoj2732)的更多相关文章
- LeetCode刷题系列
LeetCode 我们工作面试和提高自身数据结构和算法能力的时候往往需要刷刷题,我选择LeetCode是通过一个留学论坛了解的.专业,覆盖语种全面. 提前说说刷题的心得: 尽量手写代码,少使用IDE的 ...
- ife任务刷题总结(一)-css reset与清除浮动
本文同时发布于本人的个人网站www.yaoxiaowen.com 百度创办的前端技术学院,是一个面向大学生的前端技术学习平台.虽然只有大学生才有资格报名,提交代码进行比赛排名.但是这并不妨碍我们这些初 ...
- 刷题ING...
我用codeVS刷题.. 努力准备!!
- XidianOJ 1020 ACMer去刷题吧
题目描述 刷题是每个ACMer必由之路,已知某oj上有n个题目,第i个题目小X能做对的概率为Pi(0<=Pi<=1,1<=i<=n) 求小X至少做对k道题的概率 输入 第一行输 ...
- 【BZOJ-4590】自动刷题机 二分 + 判定
4590: [Shoi2015]自动刷题机 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 156 Solved: 63[Submit][Status ...
- NOI题库分治算法刷题记录
今天晚自习机房刷题,有一道题最终WA掉两组,极其不爽,晚上回家补完作业欣然搞定它,特意来写篇博文来记录下 (最想吐槽的是这个叫做分治的分类,里面的题目真的需要分治吗...) 先来说下分治法 分治法的设 ...
- NOI题库刷题日志 (贪心篇题解)
这段时间在NOI题库上刷了刷题,来写点心得和题解 一.寻找平面上的极大点 2704:寻找平面上的极大点 总时间限制: 1000ms 内存限制: 65536kB 描述 在一个平面上,如果有两个点( ...
- 用js刷题的一些坑
leecode可以用js刷题了,我大js越来越被认可了是吧.但是刷题中会因为忽略js的一些特性掉入坑里.我这里总结一下我掉过的坑. 坑1:js中数组对象是引用对象 js中除了object还有数组对象也 ...
- BZOJ4590 自动刷题机
Description 曾经发明了信号增幅仪的发明家SHTSC又公开了他的新发明:自动刷题机--一种可以自动AC题目的神秘装置.自动 刷题机刷题的方式非常简单:首先会瞬间得出题目的正确做法,然后开始写 ...
随机推荐
- Java、Node.js、PHP还是.Net? 无论你选谁,我都能教你一招!
七夕如期而至,不该来的终究还是来了.再傲娇的单身贵族恐怕也难免在今天会感觉一丝丝的空虚.还好你关注了我,因为接下来我准备了三大招教你一个人…..也可以优雅地过七夕. 招式一:移形幻影,无中生有 七夕当 ...
- LR中测试dubbo接口的脚本
import lrapi.lr;import com.alibaba.dubbo.config.ApplicationConfig;import com.alibaba.dubbo.config.Re ...
- java 核心技术卷一笔记 6 .2.3 接口 lambda 表达式 内部类
6.2.3 对象克隆 Cloneable 接口,这个接口指示一个类提供了一个安全的clone方法.(稍作了解) 为一个对象引用的变量建立副本时,原变量和副本都是同一个对象的引用,任何一个变量改变都 ...
- js 前端不调接口直接下载图片
// 下载图片 downPhoto (path) { this.downloadFiles(path) }, // 下载 downloadFiles (content) { console.log(c ...
- JS常用操作节点的方法
js常见的创建dom节点的方法有 createElement() 创建一个元素节点 => 接收参数为string类型的nodename createTextNode() 创建一个文本节点 =&g ...
- java 正则表达式如何提取中文的问题
String regex="([\u4e00-\u9fa5]+)"; String str="132更新至456"; Matcher matcher = Pat ...
- 题解 CF440A 【Forgotten Episode】
博客阅读更好 虽然这道题是紫题,但实际难度应该是橙题吧 首先,看到标签…… 紫题?但题目也太…… 这道题教会我们不要看标签 好了,废话少说,看到楼下许多大佬都用了数组,但我觉得可以不用 为什么? 我也 ...
- MAC环境Android SDK环境变量配置
一.材料 1.Mac设备1台: 2.下载并更新android SDK:示列中sdk存放路径为/Users/gametest/Library/Android/sdk 二.操作步骤 1.启动Termina ...
- request :fail url not in domain list
1.可点击开发者工具右上角 详情-域名信息,看看是否配置了域名: 2. 手机预览小程序的时候,打开调试
- poi导出word模板项目实例(一个文件)
在页面上填写值,然后导出到word模板中,并把页面上的值带到模板中,也就是导出word文档,提前有word 的模板形式, 1.jsp 页面 <table class="formTa ...