zoukankan      html  css  js  c++  java
  • BZOJ3564 [SHOI2014]信号增幅仪

    先把椭圆长轴转到x轴上,然后把x轴按照比例缩回去,于是就变成了最小圆覆盖问题,上板子。。。就行

      1 /**************************************************************
      2     Problem: 3564
      3     User: rausen
      4     Language: C++
      5     Result: Accepted
      6     Time:256 ms
      7     Memory:2380 kb
      8 ****************************************************************/
      9  
     10 #include <cstdio>
     11 #include <cmath>
     12  
     13 using namespace std;
     14 typedef double lf;
     15 const int N = 5e4 + 5;
     16 const lf pi = acos(-1.0);
     17 const lf eps = 1e-7;
     18  
     19 inline int read();
     20  
     21 template <class T> T sqr(T x) {
     22     return x * x;
     23 }
     24  
     25 struct point {
     26     lf x, y;
     27     point() {}
     28     point(lf _x, lf _y) : x(_x), y(_y) {}
     29      
     30     inline void get() {
     31         x = read(), y = read();
     32     }
     33     inline void rev(lf a) {
     34         static lf tx, ty;
     35         tx = x * cos(a) - y * sin(a), ty = x * sin(a) + y * cos(a);
     36         x = tx, y = ty;
     37     }
     38      
     39     inline point operator + (const point &p) const {
     40         return point(x + p.x, y + p.y);
     41     }
     42     inline point operator - (const point &p) const {
     43         return point(x - p.x, y - p.y);
     44     }
     45     inline point operator / (lf t) const {
     46         return point(x / t, y / t);
     47     }
     48     inline lf operator * (const point &p) const {
     49         return x * p.y - y * p.x;
     50     }
     51      
     52     friend inline lf dis2(const point &p) {
     53         return sqr((lf) p.x) + sqr((lf) p.y);
     54     }
     55     friend inline point work(const point &a, const point &b, const point &c) {
     56         static point p, q, res;
     57         static lf d, ab, bc, ac;
     58         p = b - a, q = c - a, d = p * q * 2;
     59         if (fabs(d) < eps) {
     60             ab = dis2(b - a), bc = dis2(c - b), ac = dis2(c - a);
     61             if (ab - bc >= eps && ab - ac >= eps) return (a + b) / 2;
     62             if (bc - ab >= eps && bc - ac >= eps) return (b + c) / 2;
     63             return (a + c) / 2;
     64         }
     65         return point(dis2(p) * q.y - dis2(q) * p.y, dis2(q) * p.x - dis2(p) * q.x) / d + a;
     66     }
     67 } p[N], c[N];
     68  
     69 int n, cnt;
     70 lf alpha, P;
     71  
     72 inline lf min_cover() {
     73     static int i, j, k;
     74     static lf rad2;
     75     rad2 = cnt = 0;
     76     for (i = 1; i <= n; ++i) if (dis2(p[i] - c[cnt]) > rad2) {
     77         c[cnt] = p[i], rad2 = 0.0;
     78         for (j = 1; j < i; ++j) if (dis2(p[j] - c[cnt]) > rad2) {
     79             c[cnt] = (p[i] + p[j]) / 2.0, rad2 = dis2(p[i] - c[cnt]);
     80             for (k = 1; k < j; ++k) if (dis2(p[k] - c[cnt]) > rad2)
     81                 c[cnt] = work(p[i], p[j], p[k]), rad2 = dis2(p[i] - c[cnt]);
     82         }
     83     }
     84     return sqrt(rad2);
     85 }
     86   
     87  
     88 int main() {
     89     int i;
     90     n = read();
     91     for (i = 1; i <= n; ++i) p[i].get();
     92     alpha = (lf) read() / 180.0 * pi, P = read();
     93     for (i = 1; i <= n; ++i)
     94         p[i].rev(-alpha), p[i].x /= P;
     95     printf("%.3lf
    ", min_cover());
     96     return 0;
     97 }
     98  
     99 inline int read() {
    100     static int x, sgn;
    101     static char ch;
    102     x = 0, sgn = 1, ch = getchar();
    103     while (ch < '0' || '9' < ch) {
    104         if (ch == '-') sgn = -1;
    105         ch = getchar();
    106     }
    107     while ('0' <= ch && ch <= '9') {
    108         x = x * 10 + ch - '0';
    109         ch = getchar();
    110     }
    111     return sgn * x;
    112 }
    View Code

    (p.s. rank.1液!转圈~转圈~)

    By Xs酱~ 转载请说明 博客地址:http://www.cnblogs.com/rausen
  • 相关阅读:
    Android自定义权限和使用权限
    SendInput模拟Win(VK_LWIN)键的问题
    难以置信,根本就没拖延症!
    Android RecyclerView单击、长按事件:基于OnItemTouchListener +GestureDetector标准实现(二),封装抽取成通用工具类
    Android RecyclerView单击、长按事件标准实现:基于OnItemTouchListener + GestureDetector
    Android ViewPager Fragment使用懒加载提升性能
    Android快捷便利但不常被使用的原生工具类
    Android TextView图文混合编排
    JQuery中$.ajax()方法参数详解 及 async属性说明
    jQuery.ajaxComplete() 函数详解
  • 原文地址:https://www.cnblogs.com/rausen/p/4464340.html
Copyright © 2011-2022 走看看