24h購物| | PChome| 登入
2012-05-13 21:28:23| 人氣478| 回應0 | 上一篇 | 下一篇

[NPSC][2006 高中組][B.古力德] 最小覆蓋圓

推薦 0 收藏 0 轉貼0 訂閱站台

#include <stdio.h>
#include <math.h>
#define eps 1e-8
struct Point {
    float x, y;
};
float dist(Point &a, Point &b) {
    return (a.x-b.x)*(a.x-b.x)+(a.y-b.y)*(a.y-b.y);
}
Point circle(Point &a, Point &b, Point &c) {

    static Point ab, ac, o;
    static float a1, b1, c1, a2, b2, c2, D, D1, D2;
    ab.x = (a.x+b.x)/2, ab.y = (a.y+b.y)/2;
    ac.x = (a.x+c.x)/2, ac.y = (a.y+c.y)/2;
    a1 = a.x-b.x, b1 = a.y-b.y;
    c1 = a1*ab.x + b1*ab.y;
    a2 = a.x-c.x, b2 = a.y-c.y;
    c2 = a2*ac.x + b2*ac.y;
    D = a1*b2-a2*b1;
    D1 = c1*b2-c2*b1;
    D2 = a1*c2-a2*c1;
    o.x = D1/D;
    o.y = D2/D;
    return o;
}
Point minCoverCircle(Point p[], int n) {
    Point c;
    float cr = 0.0;
    int i, j, k;
    c = p[0];
    for(i = 1; i < n; i++) {
        if(dist(p[i], c) >= cr+eps) {
            c = p[i], cr = 0;
            for(j = 0; j < i; j++) {
                if(dist(p[j], c) >= cr+eps) {
                    c.x = (p[i].x+p[j].x)/2;
                    c.y = (p[i].y+p[j].y)/2;
                    cr = dist(p[i], c);
                    for(k = 0; k < j; k++) {
                        if(dist(p[k], c) >= cr+eps) {
                            c = circle(p[i], p[j], p[k]);
                            cr = dist(p[i], c);
                        }
                    }
                }
            }
        }
    }
    printf("%.3f\n", sqrt(cr));
}
Point p[1000000];
int main() {/*
    freopen("pb.in", "rt", stdin);
    freopen("pb.out", "w+t", stdout);*/
    int n, m, i, Case = 0;
    while(scanf("%d %d", &n, &m) == 2) {
        if(n == 0 && m == 0)
            break;
        for(i = 0; i < m; i++) {
            scanf("%f %f", &p[i].x, &p[i].y);
        }
        minCoverCircle(p, m);
    }
    return 0;
}

台長: Morris
人氣(478) | 回應(0)| 推薦 (0)| 收藏 (0)| 轉寄
全站分類: 不分類 | 個人分類: NPSC |
此分類下一篇:[ZJ] a361. A. 賓果遊戲
此分類上一篇:b040. E. 魔法部的任務

是 (若未登入"個人新聞台帳號"則看不到回覆唷!)
* 請輸入識別碼:
請輸入圖片中算式的結果(可能為0) 
(有*為必填)
TOP
詳全文