题意

给\(n\)个点,求一个能覆盖所有点的面积最小的圆。(\(n \le 50000\))

分析

随机增量法

题解

理论上\(O(n^3)\)暴力,实际上加上随机化后期望是\(O(n)\)的。

算法大概就是:

假设我们已经得到了最小覆盖圆\(O\),然后现在考虑假如第\(i\)个点进去。

如果第\(i\)个点在圆内或在圆上,则不需要更改。如果在圆外,显然最小覆盖圆要经过这个点。

于是又从头考虑\(1 \sim i-1\)这些点,我们只需要找到一个经过\(i\)点的覆盖所有点的最小覆盖圆。于是同前面一步一直类推下去。

直到出现了最小覆盖圆要经过三个点。于是三点确定一个圆就行了。

  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. typedef double lf;
  4. const int N=1000005;
  5. const lf eps=1e-8;
  6. int n;
  7. struct ip {
  8. lf x, y;
  9. ip(lf _x=0, lf _y=0) : x(_x), y(_y) { }
  10. void scan() {
  11. scanf("%lf%lf", &x, &y);
  12. }
  13. }a[N];
  14. inline lf sqr(lf a) {
  15. return a*a;
  16. }
  17. inline lf dist(ip &a, ip &b) {
  18. return sqr(a.x-b.x)+sqr(a.y-b.y);
  19. }
  20. inline ip getO(ip &a, ip &b, ip &c) {
  21. lf x1=b.x-a.x, y1=b.y-a.y, z1=(sqr(x1)+sqr(y1))/2,
  22. x2=c.x-a.x, y2=c.y-a.y, z2=(sqr(x2)+sqr(y2))/2,
  23. s=x1*y2-x2*y1;
  24. if(s>-eps && s<eps) {
  25. if(x1*x2<-eps) {
  26. return ip((b.x+c.x)/2, (b.y+c.y)/2);
  27. }
  28. return ip((a.x+c.x)/2, (a.y+c.y)/2);
  29. }
  30. return ip(a.x+(z1*y2-z2*y1)/s, a.y+(x1*z2-x2*z1)/s);
  31. }
  32. inline int rand() {
  33. typedef long long ll;
  34. static ll mo=1e9+7, g=78125, now=2333;
  35. return (now*=g)%=mo;
  36. }
  37. int main() {
  38. scanf("%d", &n);
  39. for(int i=0; i<n; ++i) {
  40. a[i].scan();
  41. if(i) {
  42. swap(a[i], a[rand()%i]);
  43. }
  44. }
  45. ip o=a[0];
  46. lf r=0;
  47. for(int i=1; i<n; ++i) {
  48. if(dist(a[i], o)-r>eps) {
  49. o=a[i];
  50. r=0;
  51. for(int j=0; j<i; ++j) {
  52. if(dist(a[j], o)-r>eps) {
  53. o=ip((a[i].x+a[j].x)/2, (a[i].y+a[j].y)/2);
  54. r=dist(a[i], o);
  55. for(int k=0; k<j; ++k) {
  56. if(dist(a[k], o)-r>eps) {
  57. o=getO(a[i], a[j], a[k]);
  58. r=dist(a[k], o);
  59. }
  60. }
  61. }
  62. }
  63. }
  64. }
  65. printf("%.2f %.2f %.2f\n", o.x, o.y, sqrt(r));
  66. return 0;
  67. }

【BZOJ】2823: [AHOI2012]信号塔的更多相关文章

  1. 2018.07.04 BZOJ 2823: AHOI2012信号塔(最小圆覆盖)

    2823: [AHOI2012]信号塔 Time Limit: 10 Sec Memory Limit: 128 MB Description 在野外训练中,为了确保每位参加集训的成员安全,实时的掌握 ...

  2. BZOJ 2823: [AHOI2012]信号塔

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2823 随机增量法.不断加点维护圆,主要是三点共圆那里打得烦(其实也就是个两中垂线求交点+联立方 ...

  3. BZOJ.2823.[AHOI2012]信号塔(最小圆覆盖 随机增量法)

    BZOJ 洛谷 一个经典的随机增量法,具体可以看这里,只记一下大体流程. 一个定理:如果一个点\(p\)不在点集\(S\)的最小覆盖圆内,那么它一定在\(S\bigcup p\)的最小覆盖圆上. 所以 ...

  4. bzoj 2823: [AHOI2012]信号塔 最小圆覆盖

    题目大意: 给定n个点,求面积最小的园覆盖所有点.其中\(n \leq 10^6\) 题解: 恩... 刚拿到这道题的时候... 什么???最小圆覆盖不是\(O(n^3)\)的随机增量算法吗????? ...

  5. bzoj2823[AHOI2012]信号塔

    2823: [AHOI2012]信号塔 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1190  Solved: 545[Submit][Status ...

  6. 【BZOJ2823】[AHOI2012]信号塔(最小圆覆盖)

    [BZOJ2823][AHOI2012]信号塔(最小圆覆盖) 题面 BZOJ 洛谷 相同的题: BZOJ1 BZOJ2 洛谷 题解 模板题... #include<iostream> #i ...

  7. 【bzoj2823】 AHOI2012—信号塔

    http://www.lydsy.com/JudgeOnline/problem.php?id=2823 (题目链接) 题意 求最小圆覆盖 Solution 关于最小圆覆盖的做法,论文里面都有.其实真 ...

  8. (bzoj1337 || 洛谷P1742 最小圆覆盖 )|| (bzoj2823 || 洛谷P2533 [AHOI2012]信号塔)

    bzoj1337 洛谷P1742 用随机增量法.讲解:https://blog.csdn.net/jokerwyt/article/details/79221345 设点集A的最小覆盖圆为g(A) 可 ...

  9. AHOI2012 信号塔 | 最小圆覆盖模板

    题目链接:戳我 最小圆覆盖. 1.枚举第一个点,考虑当前圆是否包含了这个点,如果没有,则把圆变成以这个点为圆心,半径为0的圆. 2.枚举第二个点,考虑圆是否包含了这个点,如果没有,则把圆变成以这两个点 ...

随机推荐

  1. c++11的初始化

    c++11 中类型初始更加方便 比如     vector<int> vec = {1,2,3}; vector<int> vec{1,2,3}; map<string, ...

  2. mysql基础一

    一.概述 1.什么是数据库 ? 答:数据的仓库,如:在ATM的示例中我们创建了一个 db 目录,称其为数据库 2.什么是 MySQL.Oracle.SQLite.Access.MS SQL Serve ...

  3. 《图形学》实验四:中点Bresenham算法画直线

    开发环境: VC++6.0,OpenGL 实验内容: 使用中点Bresenham算法画直线. 实验结果: 代码: //中点Bresenham算法生成直线 #include <gl/glut.h& ...

  4. ytu 1067: 顺序排号(约瑟夫环)

    1067: 顺序排号 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 31  Solved: 16[Submit][Status][Web Board] ...

  5. Oracle ASM

    一 Oracle ASM簡介 Oracle 10g推出的管理磁盤的新方式,用於取代LVM技術.主要用于RAC環境 二 Oracle ASM的配置安裝 1.安裝asm包 RedHat Linux5.x ...

  6. WPF QuickStart系列之样式和模板(Style and Template)

    在WPF桌面程序中,当我们想构建一个统一的UI表现时(在不同操作系统下,显示效果一致),此时我们就需要使用到WPF中的样式和模板技术.简单来说,如果我们需要简单的给一个Button设置宽,高,Marg ...

  7. 用康托展开实现全排列(STL、itertools)

    康拓展开: $X=a_n*(n-1)!+a_{n-1}*(n-2)!+\ldots +a_2*1!+a_1*0!$ X=an*(n-1)!+an-1*(n-2)!+...+ai*(i-1)!+...+ ...

  8. [JavaCore]JAVA中的泛型

    JAVA中的泛型 [更新总结] 泛型就是定义在类里面的一个类型,这个类型在编写类的时候是不确定的,而在初始化对象时,必须确定该类型:这个类型可以在一个在里定义多个:在一旦使用某种类型,在类方法中,那么 ...

  9. 孙鑫VC学习笔记:多线程编程

    孙鑫VC学习笔记:多线程编程 SkySeraph Dec 11st 2010  HQU Email:zgzhaobo@gmail.com    QQ:452728574 Latest Modified ...

  10. 【转】Linux IO实时监控iostat命令详解

    转自:http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2858810.html 简介 iostat主要用于监控系统设备的IO负载情况,iosta ...