bzoj1007[HNOI2008]水平可见直线

题意:

平面上有n条直线L1,L2,...Ln,若在y值为正无穷大处往下看,能见到Li的某个子线段,则称Li为可见的,否则Li为被覆盖的。给出n条直线,已知其斜率和截距,且n条直线两两不重合,求出所有可见的直线。

题解:

和上一道差不多,但是因为是比较随意的直线,所以还要多一些判断条件。

代码:

 1 #include <cstdio>
 2 #include <algorithm>
 3 #include <cstring>
 4 #include <cmath>
 5 #define inc(i,j,k) for(int i=j;i<=k;i++)
 6 #define eps 1e-8
 7 using namespace std;
 8
 9 struct nd{
10     int a,b,id;
11     bool operator < (const nd& x)const{
12         if(a!=x.a)return a<x.a; return b<x.b;
13     }
14 };
15 double solve(nd a,nd b){
16     return (double)(a.b-b.b)/(double)(b.a-a.a);
17 }
18 nd nds[100000],s[100000]; int ans[100000],n,tp;
19 int main(){
20     scanf("%d",&n);inc(i,1,n)scanf("%d",&nds[i].a),scanf("%d",&nds[i].b),nds[i].id=i; sort(nds+1,nds+1+n);
21     tp=1;s[tp]=nds[1];ans[tp]=nds[1].id;
22     inc(i,2,n){
23         if(nds[i].a-s[tp].a==0)tp--;
24         while(tp>=2&&solve(s[tp-1],s[tp])>=solve(s[tp],nds[i]))tp--;
25         s[++tp]=nds[i]; ans[tp]=nds[i].id;
26     }
27     sort(ans+1,ans+1+tp);inc(i,1,tp)printf("%d ",ans[i]);
28     return 0;
29 }

20160407

转载于:https://www.cnblogs.com/YuanZiming/p/5696932.html

bzoj1007[HNOI2008]水平可见直线相关推荐

  1. [BZOJ1007] [HNOI2008] 水平可见直线 (凸包)

    Description 在xoy直角坐标平面上有n条直线L1,L2,...Ln,若在y值为正无穷大处往下看,能见到Li的某个子线段,则称Li为可见的,否则Li为被覆盖的. 例如,对于直线:L1:y=x ...

  2. [BZOJ1007](HNOI2008)水平可见直线(半平面交习题)

    Description 在xoy直角坐标平面上有n条直线L1,L2,...Ln,若在y值为正无穷大处往下看,能见到Li的某个子线段,则称Li为可见的,否则Li为被覆盖的.     例如,对于直线:   ...

  3. BZOJ1007:[HNOI2008]水平可见直线(计算几何)

    Description 在xoy直角坐标平面上有n条直线L1,L2,...Ln,若在y值为正无穷大处往下看,能见到Li的某个子线段,则称Li为 可见的,否则Li为被覆盖的. 例如,对于直线: L1:y ...

  4. Bzoj1007 [HNOI2008]水平可见直线

    Time Limit: 1 Sec  Memory Limit: 162 MB Submit: 6903  Solved: 2643 Description 在xoy直角坐标平面上有n条直线L1,L2 ...

  5. bzoj 1007: [HNOI2008]水平可见直线

    1007: [HNOI2008]水平可见直线 Time Limit: 1 Sec  Memory Limit: 162 MB Submit: 7378  Solved: 2829 [Submit][S ...

  6. bzoj 1007 : [HNOI2008]水平可见直线 计算几何

    题目链接 给出n条直线, 问从y轴上方向下看, 能看到哪些直线, 输出这些直线的编号. 首先我们按斜率排序, 然后依次加入一个栈里面, 如果刚加入的直线, 和之前的那条直线斜率相等, 那么显然之前的会 ...

  7. BZOJ.1007.[HNOI2008]水平可见直线(凸壳 单调栈)

    题目链接 可以看出我们是要维护一个下凸壳. 先对斜率从小到大排序.斜率最大.最小的直线是一定会保留的,因为这是凸壳最边上的两段. 维护一个单调栈,栈中为当前可见直线(按照斜率排序). 当加入一条直线l ...

  8. _bzoj1007 [HNOI2008]水平可见直线【单调栈】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=1007 按斜率排序,去掉斜率相同时,截距较小的直线(即只保留该斜率下截距最大的直线).若当前直 ...

  9. HYSBZ/BZOJ 1007 [HNOI2008] 水平可见直线 - 计算几何

    题目描述 分析: 直角坐标系内,有n条直线分布,求:最大值(对于任意x,直线上能取到的max( f(x) ))构成的折线由哪些直线构成. Solution : 把直线按照斜率从小到大排序. 从左到右: ...

最新文章

  1. UC伯克利新机器人成果:灵活自由地使用工具
  2. matplotlib(4)饼图
  3. jsdiff 比较文本内容差异
  4. C++中的虚函数(表)实现机制以及用C语言对其进行的模拟实现
  5. 软考系统架构师笔记-最后知识点总结(四)
  6. 蓝色版去水印小程序源码+接口
  7. 用户级别线程的切换切换到内核线程_【修炼内功】[JVM] 细说线程
  8. jconsole是否可以在生产环境使用_jconsole使用
  9. 面试—每日一题(3)
  10. Linux突然断电造成系统文件损坏而无法启动
  11. java的方法分为两大类型,java题库
  12. Python 作业4+实验三
  13. IDEA启动My Eclipse项目
  14. [Pytorch]将自己的数据集载入dataloader
  15. 关于用例 前置条件等的理解(1)
  16. 02_搭建项目(servlet+java bean+jsp的商城教程)
  17. 安装计算机主板时应注意的问题,电脑DIY:电脑主板的安装以及注意事项
  18. (油猴脚本网盘下载加速)
  19. 金蝶云之家APP产品分析报告
  20. 读《IBM蓝色基因百年智慧》

热门文章

  1. Lambda 表达式(=):网络摘抄,自学用,侵删。
  2. Using string literals in ref attributes is deprecated
  3. 解决在ueditor中上传图片通过后台java+SpringMVC添加水印方法
  4. 【转】linux tar 压缩
  5. java、intellij idea、groovy
  6. 1615: [Usaco2008 Mar]The Loathesome Hay Baler麻烦的干草打包机
  7. vs增量链接、清单文件
  8. ROS教程(3)---静态NAT配置及应用 (
  9. Linux(Ubuntu)设置环境变量(转载)
  10. snipaste滚动截图方法_电脑必备!这个截图神器比QQ截图更好用