题面

传送门

题解

我连椭圆是个啥都不知道导致这么简单一道题我一点思路都没有……

我们把坐标系旋转一下,让半长轴成为新的\(x\)轴,也就是说所有点都绕原点逆时针旋转\(360-a\)度,然后再把所有点的\(x\)坐标变为原来的\({1\over p}\),跑一个最小圆覆盖就行了

  1. //minamoto
  2. #include<bits/stdc++.h>
  3. #define R register
  4. #define inline __inline__ __attribute__((always_inline))
  5. #define fp(i,a,b) for(R int i=(a),I=(b)+1;i<I;++i)
  6. #define fd(i,a,b) for(R int i=(a),I=(b)-1;i>I;--i)
  7. #define go(u) for(int i=head[u],v=e[i].v;i;i=e[i].nx,v=e[i].v)
  8. using namespace std;
  9. char buf[1<<21],*p1=buf,*p2=buf;
  10. inline char getc(){return p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++;}
  11. int read(){
  12. R int res,f=1;R char ch;
  13. while((ch=getc())>'9'||ch<'0')(ch=='-')&&(f=-1);
  14. for(res=ch-'0';(ch=getc())>='0'&&ch<='9';res=res*10+ch-'0');
  15. return res*f;
  16. }
  17. double readdb()
  18. {
  19. R double x=0,y=0.1,f=1;R char ch;
  20. while((ch=getc())>'9'||ch<'0')(ch=='-')&&(f=-1);
  21. for(x=ch-'0';(ch=getc())>='0'&&ch<='9';x=x*10+ch-'0');
  22. for(ch=='.'&&(ch=getc());ch>='0'&&ch<='9';x+=(ch-'0')*y,y*=0.1,ch=getc());
  23. return x*f;
  24. }
  25. const int N=1e5+5;const double eps=1e-6,Pi=acos(-1.0);
  26. inline double reps(){return (1.0*rand()/RAND_MAX-0.5)*eps;}
  27. inline int sgn(R double x){return x<-eps?-1:x>eps;}
  28. struct node{
  29. double x,y;
  30. inline node(){}
  31. inline node(R double xx,R double yy):x(xx),y(yy){}
  32. inline node operator +(const node &b)const{return node(x+b.x,y+b.y);}
  33. inline node operator -(const node &b)const{return node(x-b.x,y-b.y);}
  34. inline double operator *(const node &b)const{return x*b.y-y*b.x;}
  35. inline node operator *(const double &b)const{return node(x*b,y*b);}
  36. inline double operator ^(const node &b)const{return x*b.x+y*b.y;}
  37. inline double len2(){return x*x+y*y;}
  38. inline node rot(R double s,R double c){return node(x*c-y*s,x*s+y*c);}
  39. inline node rot90(){return node(-y,x);}
  40. inline void shake(){x+=reps(),y+=reps();}
  41. }p[N],o;
  42. struct Line{
  43. node p,v;
  44. inline Line(){}
  45. inline Line(R node pp,R node vv):p(pp),v(vv){}
  46. friend node cross(const Line &a,const Line &b){return a.p+a.v*(b.v*(b.p-a.p)/(b.v*a.v));}
  47. };
  48. node circle(const node &a,const node &b,const node &c){
  49. return cross(Line((a+b)*0.5,(b-a).rot90()),Line((a+c)*0.5,(c-a).rot90()));
  50. }
  51. int n;double s,c,a,b;
  52. double calc(){
  53. double r=0;o=node(0,0);
  54. random_shuffle(p+1,p+1+n);
  55. fp(i,1,n)if(sgn((p[i]-o).len2()-r)>0){
  56. o=p[i],r=0;
  57. fp(j,1,i-1)if(sgn((p[j]-o).len2()-r)>0){
  58. o=(p[i]+p[j])*0.5,r=(p[j]-o).len2();
  59. fp(k,1,j-1)if(sgn((p[k]-o).len2()-r)>0)
  60. o=circle(p[i],p[j],p[k]),r=(p[k]-o).len2();
  61. }
  62. }
  63. return sqrt(r);
  64. }
  65. int main(){
  66. srand(20030719);
  67. // freopen("testdata.in","r",stdin);
  68. n=read();
  69. fp(i,1,n)p[i].x=readdb(),p[i].y=readdb(),p[i].shake();
  70. b=read(),a=read(),b=(360-b)/180.0*Pi,s=sin(b),c=cos(b),a=1.0/a;
  71. fp(i,1,n)p[i]=p[i].rot(s,c);
  72. fp(i,1,n)p[i].x=p[i].x*a;
  73. printf("%.3lf\n",calc());
  74. return 0;
  75. }

LOJ#2190. 「SHOI2014」信号增幅仪(最小圆覆盖)的更多相关文章

  1. [LOJ 2190] 「SHOI2014」信号增幅仪

    [LOJ 2190] 「SHOI2014」信号增幅仪 链接 链接 题解 坐标系直到 \(x\) 轴与椭圆长轴平行 点的坐标变换用旋转公式就可以了 因为是椭圆,所以所有点横坐标除以 \(p\) 然后最小 ...

  2. BZOJ 3564: [SHOI2014]信号增幅仪 最小圆覆盖

    3564: [SHOI2014]信号增幅仪 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=3564 Description 无线网络基站在 ...

  3. Loj #2192. 「SHOI2014」概率充电器

    Loj #2192. 「SHOI2014」概率充电器 题目描述 著名的电子产品品牌 SHOI 刚刚发布了引领世界潮流的下一代电子产品--概率充电器: 「采用全新纳米级加工技术,实现元件与导线能否通电完 ...

  4. Loj #3096. 「SNOI2019」数论

    Loj #3096. 「SNOI2019」数论 题目描述 给出正整数 \(P, Q, T\),大小为 \(n\) 的整数集 \(A\) 和大小为 \(m\) 的整数集 \(B\),请你求出: \[ \ ...

  5. Loj #3093. 「BJOI2019」光线

    Loj #3093. 「BJOI2019」光线 题目描述 当一束光打到一层玻璃上时,有一定比例的光会穿过这层玻璃,一定比例的光会被反射回去,剩下的光被玻璃吸收. 设对于任意 \(x\),有 \(x\t ...

  6. Loj #3089. 「BJOI2019」奥术神杖

    Loj #3089. 「BJOI2019」奥术神杖 题目描述 Bezorath 大陆抵抗地灾军团入侵的战争进入了僵持的阶段,世世代代生活在 Bezorath 这片大陆的精灵们开始寻找远古时代诸神遗留的 ...

  7. Loj #2542. 「PKUWC2018」随机游走

    Loj #2542. 「PKUWC2018」随机游走 题目描述 给定一棵 \(n\) 个结点的树,你从点 \(x\) 出发,每次等概率随机选择一条与所在点相邻的边走过去. 有 \(Q\) 次询问,每次 ...

  8. Loj #3059. 「HNOI2019」序列

    Loj #3059. 「HNOI2019」序列 给定一个长度为 \(n\) 的序列 \(A_1, \ldots , A_n\),以及 \(m\) 个操作,每个操作将一个 \(A_i\) 修改为 \(k ...

  9. Loj #3056. 「HNOI2019」多边形

    Loj #3056. 「HNOI2019」多边形 小 R 与小 W 在玩游戏. 他们有一个边数为 \(n\) 的凸多边形,其顶点沿逆时针方向标号依次为 \(1,2,3, \ldots , n\).最开 ...

随机推荐

  1. rdd去重

    a=[[1,2,3,2,3,4],[3,4,5,6,7,5,3,2]]b=sc.parallelize(a) d=b.flatMap(lambda x:x)  #铺平 ,形成一个rdd e=d.dis ...

  2. linux进程的几个状态

    [linux进程的几个状态] 1. Linux进程状态:R (TASK_RUNNING),可执行状态&运行状态(在run_queue队列里的状态) 2. Linux进程状态:S (TASK_I ...

  3. Linux confluence5.8.10 wiki安装

    选择首先需要java环境 其次需要mysql mysql安装请参考: http://www.cnblogs.com/syuf/p/7818710.html 安装好mysql之后,创建一个库 # mys ...

  4. [Training Video - 1] [Selenium Basics] [What is Selenium IDE,RC,Webdriver, TestNG, Junit And Ant]

    Selenium IDE (Only support in Firefox): - Record and Run - UI interface - User extensions - Conversi ...

  5. Redis 安装配制

    Redis 安装配制 redis 安装分为单机安装.伪集群安装.集群安装. Redis 下载地址:http://www.redis.cn/download.html Redis 在线测试工具:http ...

  6. [分享]PY的Boost自动编译程序 1.1 根据环境自动编译

    Python写的Boost自动编译程序 1.1 改进: 根据自己的环境筛选出已安装环境,并列出 环境提供选择. 支持X64位的自动参数编译. 可以选择编译的参数,其他版本持续改进中 自动编译自动安装到 ...

  7. 数据挖掘潜规则zz

    声明:本文指的是做数据挖掘这行,不是数据仓库 我干这行有几年了,见了很多人,干了很多公司,爆一爆这个行业的状况吧……让后来人有所了解,也让猎头挖人挖的有点方向,起码和candidates聊天的时候不至 ...

  8. Linux守护进程编写方法及原理

    什么守护进程? 守护进程是运行在后台的一种用来提供服务的进程,他脱离控制台独立运行,守护进程是一种很有用的进 程. Linux的大多数服务器就是用守护进程实现的.比如,Internet服务器inetd ...

  9. RocketMQ 使用及常见问题

    前言 本文档是针对RocketMQ使用及常见问题的说明. 一.获取项目.安装包及文档 1. alibaba/RocketMQ https://github.com/alibaba/RocketMQ 2 ...

  10. 3dsmax导入点云数据

    http://blog.sina.com.cn/s/blog_a4f6aad50101ht99.html https://blog.csdn.net/yangziluomu/article/detai ...