博客
关于我
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/

你可能感兴趣的文章
next项目部署到服务器pm2进程守护
查看>>
nexus 介绍
查看>>
nexus上传jar
查看>>
Nexus指南中的更新强调集成和透明度的重要性
查看>>
Nexus指南已经发布
查看>>
Nexus(1):Nexus的安装与配置
查看>>
NFC技术:概述
查看>>
NFinal学习笔记 02—NFinalBuild
查看>>
NFS
查看>>
nfs mount 故障 mount.nfs: access denied by server while mounting 10.0.100.208:/backup_usb
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS 服务配置篇
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS服务器配置-服务启动与停止
查看>>
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
NFS远程目录挂载
查看>>