麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

HDU - 1007 分治(最接近點對模板)

2019-11-11 06:40:39
字體:
來源:轉載
供稿:網友

題意:

求出平面上n個點中最接近的兩個點的距離。

思路:

最接近點對問題,利用分治法解決,先按照x排序,進行分治,并對每段區間內的點再按照y排序,可以證明每段區間內的比較次數為常數,復雜度為O(nlogn)。

代碼:

#include <bits/stdc++.h>using namespace std;const int MAXN = 1e5 + 10;struct node {    double x, y;}px[MAXN], py[MAXN];bool cmpx (const node a, const node b) {    return a.x < b.x;}bool cmpy (const node a, const node b) {    return a.y < b.y;}double dis(node a, node b) {    return sqrt((a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y));}double closet(int l, int r) {    if (l + 1 == r)        return dis(px[l], px[r]);    if (l + 2 == r)        return min(dis(px[l], px[r]), min(dis(px[l + 1], px[r]), dis(px[l], px[l + 1])));    int m = (l + r) >> 1;    double ans = min(closet(l, m), closet(m + 1, r));    int num = 0;    for (int i = l; i <= r; i++)        if (px[i].x >= px[m].x - ans && px[i].x <= px[m].x + ans)            py[++num] = px[i];    sort (py + 1, py + 1 + num, cmpy);    for (int i = 1; i <= num; i++) {        for (int j = i + 1; j <= num; j++) {            if (py[j].y - py[i].y >= ans) break;                 // 這一步這樣寫,但可以證明最多不超過6個            ans = min(ans, dis(py[i], py[j]));        }    }    return ans;}int main() {    //freopen("in.txt", "r", stdin);    int n;    while(scanf("%d", &n), n) {        for (int i = 1; i <= n; i++)            scanf("%lf%lf", &px[i].x, &px[i].y);        sort (px + 1, px + 1 + n, cmpx);        PRintf("%.2f/n", closet(1, n) / 2);    }    return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 又黄又爽免费无遮挡在线观看 | 人禽l交免费视频观看 视频 | 国产精品久久久久久久久粉嫩 | 国产精品成人av片免费看最爱 | 亚洲电影在线播放 | 久草久视频 | 狠狠干伊人网 | 黄色av电影在线播放 | 亚洲一区二区三区在线免费观看 | 国产成人高清在线观看 | 国产宾馆3p国语对白 | 欧美一级片一区 | 国产成人高清成人av片在线看 | 黄色网址免费入口 | 少妇的肉体2无删减版 | 亚洲国产精久久久久久久 | 国产精品麻豆一区二区三区 | 97香蕉超级碰碰久久免费软件 | 日本欧美在线播放 | 欧美特黄a | 国产69久久精品成人看 | 国产精品午夜未成人免费观看 | 96视频在线免费观看 | 精品偷拍久久 | 超碰97最新 | 精国品产一区二区三区有限公司 | 伊人午夜视频 | 国产精品一区2区3区 | 亚洲国产超高清a毛毛片 | 国产自在线| 国产一区二区三区网站 | 狠狠干91| 成人午夜激情网 | 97超级碰碰人国产在线观看 | 国产精品美女久久久久久不卡 | 毛片一级网站 | h视频免费观看 | 久久精品亚洲一区 | 在线观看国产一区二区三区 | 国产女同疯狂激烈互摸 | 国产亚洲精品久久久久婷婷瑜伽 |