博客
关于我
poj 1981 Circle and Points
阅读量:514 次
发布时间:2019-03-07

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

Circle and Points

You are given N points in the xy-plane. You have a circle of radius one and move it on the xy-plane, so as to enclose as many of the points as possible. Find how many points can be simultaneously enclosed at the maximum. A point is considered enclosed by a circle when it is inside or on the circle.

Input

The input consists of a series of data sets, followed by a single line only containing a single character ‘0’, which indicates the end of the input. Each data set begins with a line containing an integer N, which indicates the number of points in the data set. It is followed by N lines describing the coordinates of the points. Each of the N lines has two decimal fractions X and Y, describing the x- and y-coordinates of a point, respectively. They are given with five digits after the decimal point.

You may assume 1 <= N <= 300, 0.0 <= X <= 10.0, and 0.0 <= Y <= 10.0. No two points are closer than 0.0001. No two points in a data set are approximately at a distance of 2.0. More precisely, for any two points in a data set, the distance d between the two never satisfies 1.9999 <= d <= 2.0001. Finally, no three points in a data set are simultaneously very close to a single circle of radius one. More precisely, let P1, P2, and P3 be any three points in a data set, and d1, d2, and d3 the distances from an arbitrarily selected point in the xy-plane to each of them respectively. Then it never simultaneously holds that 0.9999 <= di <= 1.0001 (i = 1, 2, 3).

Output

For each data set, print a single line containing the maximum number of points in the data set that can be simultaneously enclosed by a circle of radius one. No other characters including leading and trailing spaces should be printed.

Sample Input3

6.47634 7.69628
5.16828 4.79915
6.69533 6.20378
6
7.15296 4.08328
6.50827 2.69466
5.91219 3.86661
5.29853 4.16097
6.10838 3.46039
6.34060 2.41599
8
7.90650 4.01746
4.10998 4.18354
4.67289 4.01887
6.33885 4.28388
4.98106 3.82728
5.12379 5.16473
7.84664 4.67693
4.02776 3.87990
20
6.65128 5.47490
6.42743 6.26189
6.35864 4.61611
6.59020 4.54228
4.43967 5.70059
4.38226 5.70536
5.50755 6.18163
7.41971 6.13668
6.71936 3.04496
5.61832 4.23857
5.99424 4.29328
5.60961 4.32998
6.82242 5.79683
5.44693 3.82724
6.70906 3.65736
7.89087 5.68000
6.23300 4.59530
5.92401 4.92329
6.24168 3.81389
6.22671 3.62210
0

Sample Output2

5
5
11

题意

半径为1的圆最多能包含几个点。

#include 
#include
#include
#include
#include
#include
using namespace std;const double eps = 1e-10;int dcmp(double n) { if(fabs(n) < eps) return 0; else return n > 0 ? 1 : -1;}struct Point{ double x, y;};struct node{ double angle; int k;};Point p[303];double dis(Point a, Point b){ return sqrt((a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y));}bool cmp (node a, node b) { if(dcmp(a.angle - b.angle) != 0) return dcmp(a.angle - b.angle) > 0; else return a.k < b.k;}int main() { int n; while(scanf("%d", &n) != EOF) { if(n == 0) break; for (int i = 0; i < n; i++) scanf("%lf %lf", &p[i].x, &p[i].y); node a[90003]; int ans = 0; for (int i = 0; i < n; i++) { int cnt = 0; for(int j = 0; j < n; j++) { if(dis(p[i], p[j]) > 2.0) continue; double ang1, ang2; ang1 = atan2(p[j].y - p[i].y, p[j].x - p[i].x); ang2 = acos (dis(p[i], p[j])/ 2);//两点距离的一半除以半径1 a[cnt].angle = ang1 + ang2, a[cnt++].k = 1; a[cnt].angle = ang1 - ang2, a[cnt++].k = -1; } int sum = 0; sort(a, a + cnt , cmp); for(int i = 0; i < cnt; i++) { sum += a[i].k; ans = max(ans, sum); } } printf("%d\n", ans); }}

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

你可能感兴趣的文章
NAS个人云存储服务器搭建
查看>>
nat 网卡间数据包转发_你是不是从来没有了解过光纤网卡,它跟普通网卡有什么区别?...
查看>>
NAT-DDNS内网穿透技术,快解析DDNS的优势
查看>>
NAT-DDNS内网穿透技术,解决动态域名解析难题
查看>>
NativePHP:使用PHP构建跨平台桌面应用的新框架
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
Nat、端口映射、内网穿透有什么区别?
查看>>
nat打洞原理和实现
查看>>
NAT技术
查看>>
NAT模式/路由模式/全路由模式 (转)
查看>>
NAT模式下虚拟机centOs和主机ping不通解决方法
查看>>
NAT的两种模式SNAT和DNAT,到底有啥区别?
查看>>
NAT网络地址转换配置实战
查看>>
NAT网络地址转换配置详解
查看>>
Navicat for MySQL 命令列 执行SQL语句 历史日志
查看>>
Navicat for MySQL 查看BLOB字段内容
查看>>
Navicat for MySQL(Ubuntu)过期解决方法
查看>>
Navicat Premium 12 卸载和注册表的删除
查看>>
Navicat 导入sql文件
查看>>
navicat 添加外键1215错误
查看>>