博客
关于我
【NOIP2017提高A组模拟8.10】JZOJ7月27日提高组T3 计算几何
阅读量:300 次
发布时间:2019-03-03

本文共 1510 字,大约阅读时间需要 5 分钟。

【NOIP2017提高A组模拟8.10】JZOJ7月27日提高组T3 计算几何

题目描述:在x轴和y轴的正半轴上各有n个点,这2n个点要练成n条线段,要求任意两条线段不相交。有m个询问,每次询问给出点P(x, y),问线段OP与多少条线段相交(O为原点(0,0))。

分析:由于线段两两不相交,可以将x轴和y轴上的点从小到大排序。对于每条线段,可以求出其斜率k和截距b。对于每个询问的点P,可以求出OP的直线方程,然后找到与其他线段的交点,并判断交点是否在线段上。

代码实现:使用二分查找法快速确定交点位置,确保高效处理大量询问。代码中函数pd用于判断中间点是否满足交点条件,通过对x和y进行排序,确保线段不会相交。

题解:通过排序和二分查找,快速确定每条线段的交点位置,判断交点是否在线段上,从而计算OP与多少条线段相交。代码实现了高效的查询方法,确保在大规模数据下也能快速响应。

【题目已解答,以下为代码示例】

#include 
#include
using namespace std;bool pd(int x) { double x1, y1, kk; kk = 1.0 * y[x] / xx; x1 = b[x] / (kk - k[x]); y1 = x1 * kk; if (x1 <= x && y1 <= y) return true; else return false;}int main() { freopen("T3.in", "r", stdin); freopen("T3.out", "w", stdout); scanf("%d", &n); for (i = 1; i <= n; i++) { scanf("%d", &x[i]); } for (i = 1; i <= n; i++) { scanf("%d", &y[i]); } sort(x + 1, x + n + 1); sort(y + 1, y + n + 1); for (i = 1; i <= n; i++) { b[i] = y[i]; k[i] = -1.0 * y[i] / x[i]; } scanf("%d", &m); for (i = 1; i <= m; i++) { scanf("%d%d", &xx, &yy); l = 1; r = n; ans = 0; while (l <= r) { mid = (l + r) >> 1; if (pd(mid)) { ans = mid; l = mid + 1; } else { r = mid - 1; } } printf("%d\n", ans); } fclose(stdin); fclose(stdout); return 0;}

代码解释:首先读取输入,排序x和y轴上的点,然后计算每条线段的斜率和截距。对于每个询问,使用二分查找法确定OP直线与其他线段的交点,判断交点是否在线段上,返回相交的线段数量。

转载地址:http://gqql.baihongyu.com/

你可能感兴趣的文章
Openlayers中设置定时绘制和清理直线图层
查看>>
Openlayers图文版实战,vue项目从0到1做基础配置
查看>>
Openlayers实战:modifystart、modifyend互动示例
查看>>
Openlayers实战:判断共享单车是否在电子围栏内
查看>>
Openlayers实战:绘制图形,导出geojson文件
查看>>
Openlayers实战:绘制图形,导出KML文件
查看>>
Openlayers实战:绘制多边形,导出CSV文件
查看>>
Openlayers实战:输入WKT数据,输出GML、Polyline、GeoJSON格式数据
查看>>
Openlayers高级交互(10/20):绘制矩形,截取对应部分的地图并保存
查看>>
Openlayers高级交互(11/20):显示带箭头的线段轨迹,箭头居中
查看>>
Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
查看>>
Openlayers高级交互(15/20):显示海量多边形,10ms加载完成
查看>>
Openlayers高级交互(16/20):两个多边形的交集、差集、并集处理
查看>>
Openlayers高级交互(17/20):通过坐标显示多边形,计算出最大幅宽
查看>>
Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
查看>>
Openlayers高级交互(2/20):清除所有图层的有效方法
查看>>
Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
查看>>
Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
查看>>
Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
查看>>
Openlayers高级交互(8/20):选取feature,平移feature
查看>>