BZOJ 1007 [HNOI2008]水平可见直线
1007: [HNOI2008]水平可见直线
Time Limit: 1 Sec  Memory Limit: 162 MB
Submit: 4453  Solved: 1636
[Submit][Status][Discuss]
Description
在xoy直角坐标平面上有n条直线L1,L2,...Ln,若在y值为正无穷大处往下看,能见到Li的某个子线段,则称Li为可见的,否则Li为被覆盖的.
    例如,对于直线:
    L1:y=x; L2:y=-x; L3:y=0
    则L1和L2是可见的,L3是被覆盖的.
    给出n条直线,表示成y=Ax+B的形式(|A|,|B|<=500000),且n条直线两两不重合.求出所有可见的直线.
Input
第一行为N(0 < N < 50000),接下来的N行输入Ai,Bi
Output
从小到大输出可见直线的编号,两两中间用空格隔开,最后一个数字后面也必须有个空格
Sample Input
-1 0
1 0
0 0
Sample Output
HINT
Source
题解:做的第一道计算几何。。。
要维护的是一个下凸线一样的东西。即从左到右的交点(左)右边的直线是斜率越来越大的。
所以我们可以按斜率从小到大排序后。用一个栈来这样维护。
每次新加一条直线k,设当前栈顶直线为stack[top]=j,栈顶前一条直线为stack[top-1]=i,则若(k,j)的交点在(i,j)交点的左边或重合,则j必是被k与i及之前的直线所完全覆盖的,所以把j pop 出。直到不能再pop为止,再把k加入栈中。
上来忘了unique了,我是个脑残。。。被题目中的任一两线不重合骗了QAQ。。。
还有!!!这种stack一定要写数!组!版!的!
#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<queue>
#include<stack>
#include<cstring>
#define PAU putchar(' ')
#define ENT putchar('\n')
using namespace std;
const int maxn=+;const double esp=1e-;
struct line{int id,k,b;line(int _id=,int _k=0.0,int _b=0.0){id=_id;k=_k;b=_b;}}L[maxn],S[maxn];
bool operator<(const line&a,const line&b){return (a.k<b.k)||(a.k==b.k&&a.b>b.b);}
bool operator==(const line&a,const line&b){return a.k==b.k;}
double getx(line&a,line&b){
return (double)(b.b-a.b)/(double)(a.k-b.k);
}
int n,ans[maxn],top=;
inline int read(){
int x=,sig=;char ch=getchar();
while(!isdigit(ch)){if(ch=='-') sig=-;ch=getchar();}
while(isdigit(ch)) x=*x+ch-'',ch=getchar();
return x*=sig;
}
inline void write(int x){
if(x==){putchar('');return;}if(x<) putchar('-'),x=-x;
int len=,buf[];while(x) buf[len++]=x%,x/=;
for(int i=len-;i>=;i--) putchar(buf[i]+'');return;
}
void init(){
n=read();int x,y;
for(int i=;i<=n;i++){x=read();y=read();L[i]=line(i,x,y);}
return;
}
void work(){
sort(L+,L+n+);n=unique(L+,L+n+)-L-;
for(int i=;i<=n;i++){
while(top>&&getx(S[top-],S[top-])>getx(S[top-],L[i])-esp)top--;
S[top++]=L[i];
}
for(int i=;i<top;i++)ans[i]=S[i].id;
sort(ans+,ans+top);
return;
}
void print(){
for(int i=;i<top;i++)write(ans[i]),PAU;
return;
}
int main(){
init();work();print();return ;
}
BZOJ 1007 [HNOI2008]水平可见直线的更多相关文章
- bzoj 1007 [HNOI2008]水平可见直线(单调栈)
		
1007: [HNOI2008]水平可见直线 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 5120 Solved: 1899[Submit][Sta ...
 - 2018.07.03 BZOJ 1007: [HNOI2008]水平可见直线(简单计算几何)
		
1007: [HNOI2008]水平可见直线 Time Limit: 1 Sec Memory Limit: 162 MB Description 在xoy直角坐标平面上有n条直线L1,L2,-Ln, ...
 - BZOJ 1007  [HNOI2008]水平可见直线 (栈)
		
1007: [HNOI2008]水平可见直线 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 7940 Solved: 3030[Submit][Sta ...
 - BZOJ 1007: [HNOI2008]水平可见直线 栈/计算几何
		
1007: [HNOI2008]水平可见直线 Time Limit: 1 Sec Memory Limit: 162 MB 题目连接 http://www.lydsy.com/JudgeOnline ...
 - BZOJ 1007: [HNOI2008]水平可见直线  平面直线
		
1007: [HNOI2008]水平可见直线 Description 在xoy直角坐标平面上有n条直线L1,L2,...Ln,若在y值为正无穷大处往下看,能见到Li的某个子线段,则称Li为可见的,否则 ...
 - bzoj 1007: [HNOI2008]水平可见直线 半平面交
		
题目大意: http://www.lydsy.com/JudgeOnline/problem.php?id=1007; 题解 其实就是求每条直线的上半部分的交 所以做裸半平面交即可 #include ...
 - bzoj 1007 : [HNOI2008]水平可见直线   计算几何
		
题目链接 给出n条直线, 问从y轴上方向下看, 能看到哪些直线, 输出这些直线的编号. 首先我们按斜率排序, 然后依次加入一个栈里面, 如果刚加入的直线, 和之前的那条直线斜率相等, 那么显然之前的会 ...
 - BZOJ.1007.[HNOI2008]水平可见直线(凸壳 单调栈)
		
题目链接 可以看出我们是要维护一个下凸壳. 先对斜率从小到大排序.斜率最大.最小的直线是一定会保留的,因为这是凸壳最边上的两段. 维护一个单调栈,栈中为当前可见直线(按照斜率排序). 当加入一条直线l ...
 - BZOJ 1007 [HNOI2008]水平可见直线 ——半平面交 凸包
		
发现需要求一个下凸的半平面上有几个交点. 然后我们把它变成凸包的问题. 好写.好调.还没有精度误差. #include <map> #include <ctime> #incl ...
 
随机推荐
- iphone开发中数据持久化之——属性列表序列化(一)
			
数据持久化是应用程序开发过程中的一个基本问题,对应用程序中的数据进行持久化存储,有多重不同的形式.本系列文章将介绍在iphone开发过程中数据持久化的三种主要形式,分别是属性列表序列号.对象归档化以及 ...
 - android下大文件分割上传
			
由于android自身的原因,对大文件(如影视频文件)的操作很容易造成OOM,即:Dalvik堆内存溢出,利用文件分割将大文件分割为小文件可以解决问题. 文件分割后分多次请求服务. //文件分割上传 ...
 - 第五篇:R语言数据可视化之散点图
			
散点图简介 散点图通常是用来表述两个连续变量之间的关系,图中的每个点表示目标数据集中的每个样本. 同时散点图中常常还会拟合一些直线,以用来表示某些模型. 绘制基本散点图 本例选用如下测试数据集: 绘制 ...
 - python文件处理--笔记
			
之前一段时间一直在忙着写毕业论文,盲评搞得人心惶惶,以致于都没有看书,最近需要补上前面落下的东西. <Python3程序开发指南> 1.二进制数据的读写 二进制格式通常是占据磁盘空间最小. ...
 - 数据库内存泄漏——A SQLiteConnection object for database '/data/data/.../databases/....db' was leaked!
			
详细异常: A SQLiteConnection object for database '/data/data/.../database/....db' was leaked! Please ...
 - Web开发 < base target>
			
target就是点击链接后跳转到的目标页.通俗点说,就是你当前页面上的链接<a>,也包括<img>.<link>.<form>,除非你指定了target ...
 - contains选择器
			
有这样一个问题: 一个列表里面,很多option,但是在不知道value,只知道他的内容的时候,怎么进行选择,比如: 北京市天津市上海市重庆市 在不知道他的value和index的时候,选择北京市,能 ...
 - js求字符长度
			
</script> <!DOCTYPE html> <html lang="en"> <head> <meta charset ...
 - 【转】UITextView的使用详解
			
//初始化并定义大小 UITextView *textview = [[UITextView alloc] initWithFrame:CGRectMake(20, 10, 280, 30)]; te ...
 - AlertView + Block 的使用
			
AlertView的使用还是很频繁的,扁平化以后似乎也不是那么丑了,但是到现在为止官方还是在用Delegate来处理点击事件,很影响程序的可读性. 如果用Block那么就会一目了然.自己本来想写一个, ...