博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SOJ - 11512
阅读量:6262 次
发布时间:2019-06-22

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

Constraints

Time Limit: 2 secs, Memory Limit: 256 MB

Description

 

On the opening ceremony of World Cup there was a part where many kids from around the world was trying to make a big circle on the field which symbolized tolerance and multicultural friendship.

They succeed in making a perfect circle, but as they didn't practice very much, kids weren't uniformly distributed on circle. You spotted that very quickly, and you want to know what is the minimum distance between some two kids.

 

Input

 

First line of the input contains number N (2<=N<=10^5) representing number of kids. Each of next N lines contains two real numbers rounded on two decimal places – coordinates of the each kid. All coordinates will be in interval [-10^6, 10^6]. It is guaranteed that all points will be on circle.

 

 

Output

 

First and only line of output should contain one real number (rounded on two decimal places) – Euclidian distance between two nearest kids. Euclidian distance between points (x1, y1) and (x2, y2) is sqrt((x1-x2)^2+(y1-y2)^2).

 

Sample Input

51.00 4.00-0.50 -1.604.00 1.003.12 3.12-1.60 -0.50

Sample Output

1.56

Hint

 

In the sample, Kids at points (−0.50,−1.60) and (−1.60,−0.50) are nearest and distance between them is 1.56.

 

Problem Source

2014年每周一赛第七场/JBOI 2014

 

题意:求圆上若干点形成的最短弦长度。

思路:先任选三点确定圆心(两弦中垂线交点),再将整个圆平移,使圆心和坐标原点重合,这样就可以从x轴正半轴开始按逆时针将各个点排序,然后再求相邻两点所形成的弦的长度,取最小的就是所求答案。

 

1 // Problem#: 11512 2 // Submission#: 3027891 3 // The source code is licensed under Creative Commons Attribution-NonCommercial-ShareAlike 3.0 Unported License 4 // URI: http://creativecommons.org/licenses/by-nc-sa/3.0/ 5 // All Copyright reserved by Informatic Lab of Sun Yat-sen University 6 #include
7 using namespace std; 8 typedef long long ll; 9 struct P{10 double x,y;11 };12 vector

v;13 int n;14 double X,Y;15 inline double d2(P a,P b)16 {17 return (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y);18 }19 int F(P p)20 {21 if(p.y == 0)return p.x > 0 ? 0 : 4;22 if(p.x == 0)return p.y > 0 ? 2 : 6;23 if(p.x > 0 && p.y > 0)return 1;24 if(p.x < 0 && p.y > 0)return 3;25 if(p.x < 0 && p.y < 0)return 5;26 if(p.x > 0 && p.y < 0)return 7;27 }28 bool cmp(const P& a,const P& b)29 {30 int fa = F(a),fb = F(b);31 if(fa != fb)return fa < fb;32 else return a.y * b.x < a.x * b.y;33 }34 int main()35 {36 int i;37 while(~scanf("%d",&n))38 {39 v.clear();40 for(i=0;i

 

PS:原题数据貌似不够强,去掉第70行代码也能AC,实际上过不了上面那组数据。

转载于:https://www.cnblogs.com/gangduo-shangjinlieren/p/4041729.html

你可能感兴趣的文章
装机 win7 64 IE11
查看>>
约瑟夫环问题
查看>>
五子棋
查看>>
和为S的连续正数序列
查看>>
三周的 软件工程实践课 课程安排建议
查看>>
解决冲突-git入门教程
查看>>
修改ssh端口后无法连接ssh了?
查看>>
[android] 隐式意图的配置
查看>>
HQL: Hibernate查询语言
查看>>
SQL优化之六脉神剑
查看>>
java生成随机字符串uuid
查看>>
黄永成-thinkphp讲解-个人博客讲解26集
查看>>
Mongodb(2)创建数据库,删除数据库,创建集合,删除集合,显示文档内容
查看>>
Tomcat禁止显示目录和文件列表
查看>>
linux mmap 详解【转】
查看>>
注释中不允许出现字符串 "--"。
查看>>
client 如何找到正确的RegionServer(HBase -ROOT-和.META.表)
查看>>
协议森林16 小美的桌号(DHCP协议)
查看>>
简单的ajax封装
查看>>
PHP初学者必须掌握的10个知识点
查看>>