欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

bzoj1007[HNOI2008]水平可见直线

发布时间:2025/7/14 编程问答 45 豆豆
生活随笔 收集整理的这篇文章主要介绍了 bzoj1007[HNOI2008]水平可见直线 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

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]水平可见直线的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。