青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

算法學(xué)社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
題目描述:
   在無限平面上有N(N<1,000)個(gè)圓。問一條直線最多可以“穿過”幾個(gè)圓,相切也算。

算法分析:
   
   這樣的線一定是某兩個(gè)圓的切線。但是枚舉切線再O(N)判斷的話肯定會(huì)T。

   于是我們枚舉每個(gè)“中心圓”,求出這個(gè)圓與其他所有圓的切線。并極角排序。
   把每個(gè)切線想像成事件點(diǎn),每個(gè)事件點(diǎn)要么增加一個(gè)圓,要么刪除一個(gè)圓。

   這樣的話對(duì)這個(gè)環(huán)行區(qū)間進(jìn)行統(tǒng)計(jì)就可以了。
   
   求切線的時(shí)候,要判斷中心圓與其他圓的關(guān)系: 包含,內(nèi)切or外切,相交,被包含,分離。
   求切線其實(shí)只需要求一個(gè)角就可以了,不需要求完整的兩點(diǎn)式。

#include<iostream>
#include<cassert>
#include<algorithm>
#include<cstdio>
#include<complex>
#include<cmath>
using namespace std;
// template
typedef complex<double> pnt;
typedef pair<pnt,double> circle;
const int N = 1005;
const double eps = 1e-10;
const double pi = acos(-1.0);
inline bool eq(double a, double b){return abs(b-a) < eps;}
inline double fix(double arg) {
    while(arg > pi) arg -= 2*pi;
    while(arg <= -pi) arg += 2*pi;
    return arg;
}
circle num[N];
struct line {
    int id,c;
    double arg;
    line(){}
    line(int _id,int _c,double _arg) :
    id(_id) , c(_c), arg(_arg){
//        cout<<"add: "<<id<<" "<<arg<<" "<<c<<endl;
    }
    bool operator < (const line& A) const{
        return eq(arg , A.arg) ? c > A.c : arg < A.arg;
    }
} Line[N<<2];
// cut line
#define ht first
#define rs second
inline void cut_line(const circle &A, const circle &B, int& ans, int& cnt,const int& id) {
    double d = abs(A.ht - B.ht) ;
    if(d <= abs(A.rs - B.rs)) {
        if(d <= B.rs - A.rs ) {ans ++; return ;}
        if(eq(d , A.rs - B.rs) ) {
            Line[cnt++] = line(id, 1 , arg(B.ht - A.ht));
            Line[cnt++] = line(id,-1 , arg(B.ht - A.ht));
        }
        return ;
    }
    double t;
    t = acos((A.rs - B.rs)/ d);
    double ag = arg(B.ht - A.ht);
    Line[cnt++] = line(id, 1 , fix(ag-t));
    Line[cnt++] = line(id,-1 , fix(ag+t));
    if(d > A.rs + B.rs + eps) {
        double t = acos((A.rs + B.rs)/d);
        Line[cnt++] = line(id, 1 , fix(ag+t));
        Line[cnt++] = line(id,-1 , fix(ag-t));
    }
}
// solve
bool vis[N];
int work(int n, int len){
    int ans = 0, sum = 0;
    for(int i=0;i<n;i++){
        vis[i] = 0;
    }
    for(int i=0;i<len+len;i++) {
        int k = i%len;
        int id = Line[k].id;
        int c = Line[k].c;
        if(c == 1){
            assert(vis[id]==0);
            vis[id] = 1; sum ++;
        }
        else if(c == -1) {
            if(vis[id] == 1)
                sum --, vis[id] = 0;
        }
        if(sum > ans ) ans = sum;
    }
    return ans;
}
// main
int main(){
    int cas;
    cin >> cas;
    for(int oo=1; oo<= cas; oo++) {
        int n,len = 0;
        scanf("%d",&n);
        for(int i=0;i<n;i++) {
            int x,y,r;
            scanf("%d%d%d",&x,&y,&r);
            num[i] = make_pair(pnt(x,y) , r);
        }
        int ans = 0;
        for(int s = 0; s < n; s ++) {
//            cout<<"start: "<<s<<endl;
            len = 0; int sum = 1;
            for(int i=0;i< n; i++) if(i!=s) 
                cut_line(num[s] , num[i], sum, len, i);
            sort(Line, Line + len);
            sum += work(n,len);
            if(sum > ans) ans = sum;
        }
        printf("Case #%d: %d\n",oo, ans);
    }
}
posted on 2012-08-06 14:58 西月弦 閱讀(1260) 評(píng)論(0)  編輯 收藏 引用 所屬分類: 解題報(bào)告
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久三级视频| 国产三级欧美三级日产三级99| 午夜精品久久久久久| 亚洲人成网站777色婷婷| 1024精品一区二区三区| 国产在线精品一区二区夜色| 国产一区在线播放| 国产精品久久久久久久免费软件| 国产精品极品美女粉嫩高清在线| 欧美一区二区三区免费大片| 9人人澡人人爽人人精品| 亚洲精品1234| 亚洲一区二区三区免费视频 | 久久爱91午夜羞羞| 欧美综合国产精品久久丁香| 久久福利资源站| 欧美福利在线| 国产一区二区三区四区hd| 最新69国产成人精品视频免费| 在线视频你懂得一区| 久久黄色网页| 中日韩美女免费视频网址在线观看| 久久久精品一区二区三区| 欧美成人精品激情在线观看| 亚洲精品国产品国语在线app | 国产综合色精品一区二区三区| 亚洲精品美女在线观看| 久久精品视频免费观看| 国产欧美一区二区精品性色| 亚洲欧洲一区二区在线播放| 久久久福利视频| 性欧美暴力猛交另类hd| 国产精品免费一区二区三区观看| 亚洲精品免费在线| 国产精品二区在线| 一本色道久久综合亚洲91| 亚洲国产激情| 欧美日韩黄色大片| 亚洲午夜免费福利视频| 亚洲精品日韩激情在线电影| 欧美激情片在线观看| 亚洲裸体视频| 亚洲永久免费观看| 国产一区二区视频在线观看| 久久久夜夜夜| 欧美激情按摩在线| 欧美一级网站| 久久久国产精品亚洲一区| 日韩视频一区二区三区在线播放免费观看 | 国产精品综合久久久| 久久久精品性| 欧美日韩国产色视频| 久久激情综合网| 久久国产天堂福利天堂| 噜噜噜在线观看免费视频日韩| 日韩系列欧美系列| 小辣椒精品导航| 亚洲免费视频观看| 免费不卡在线观看av| 欧美在线一二三| 国产精品毛片在线| 欧美不卡福利| 欧美日韩一区二区在线观看| 久久青草欧美一区二区三区| 欧美日韩在线播放三区四区| 欧美激情麻豆| 依依成人综合视频| 欧美亚洲综合网| 久久av一区二区三区| 国产精品网站在线播放| 亚洲欧美日韩在线综合| 亚洲午夜羞羞片| 欧美视频在线播放| 亚洲精品精选| 中国亚洲黄色| 国产精品免费一区二区三区在线观看| 亚洲国产精品999| 中国成人黄色视屏| 欧美日韩亚洲一区二区| 一区二区三区不卡视频在线观看| 国产精品99久久久久久久vr| 欧美午夜电影在线观看| 亚洲欧美一区二区在线观看| 久久久视频精品| 一区二区欧美在线| 国产精品一级| 免费成人av在线看| 西西人体一区二区| 你懂的亚洲视频| 亚洲一区二区3| 亚洲国产美女久久久久| 国产精品久久久久久亚洲毛片 | 国产美女高潮久久白浆| 久久久噜噜噜久久| 一区二区不卡在线视频 午夜欧美不卡在 | 中文在线一区| 狼人天天伊人久久| 99国产精品| 欧美激情第一页xxx| 99热精品在线观看| 美女主播视频一区| 欧美自拍偷拍午夜视频| 日韩视频免费观看| 亚洲高清网站| 国一区二区在线观看| 国产精品成人播放| 国产精品h在线观看| 欧美激情在线免费观看| 久久精品国产91精品亚洲| 午夜伦欧美伦电影理论片| 日韩网站在线| 午夜精品久久久久影视| 国产精品久久久对白| 久久久久久久综合| 亚洲欧美日韩综合| 亚洲午夜一区二区| 中文精品视频一区二区在线观看| 最新国产成人在线观看| 欧美激情视频给我| 欧美激情中文字幕一区二区| 蜜桃久久精品乱码一区二区| 男人天堂欧美日韩| 影音先锋久久久| 国内外成人免费激情在线视频网站 | 国产精品推荐精品| 国产一区二三区| 一区二区三区日韩精品视频| 亚洲性xxxx| 久久精品女人| 亚洲国产精品精华液网站| 亚洲精品日韩一| 久久久久国产一区二区| 欧美电影资源| 国产一区二区按摩在线观看| 亚洲电影免费观看高清完整版| 一区二区日韩精品| 免费观看成人www动漫视频| 亚洲欧洲日韩女同| 久久精品99久久香蕉国产色戒| 欧美日韩国产精品| 亚洲级视频在线观看免费1级| 性18欧美另类| 夜夜嗨av一区二区三区网站四季av| 久久精精品视频| 国产一区二区日韩精品欧美精品| 一区二区三区产品免费精品久久75| 久久先锋影音av| 一本色道久久加勒比88综合| 欧美在线视频免费| 亚洲一区免费观看| 国产精品日日做人人爱 | 国产精品theporn88| 一区二区三区四区五区视频| 欧美激情影音先锋| 欧美福利视频一区| 亚洲青涩在线| 久久av一区| 亚洲电影免费观看高清完整版在线观看| 亚洲乱码国产乱码精品精| 欧美在线精品免播放器视频| 国产精品99久久久久久人 | 亚洲激情在线视频| 欧美午夜国产| 亚洲日本激情| 亚洲国产成人精品久久| 久久夜色精品| 亚洲精品一区二区网址| 国产一区二区三区高清播放| 欧美一级久久久久久久大片| 免费h精品视频在线播放| 欧美激情精品久久久久久大尺度| 狠狠色丁香久久综合频道| 亚洲国产中文字幕在线观看| 国产亚洲精品aa| 亚洲欧美清纯在线制服| 一区二区三区毛片| 欧美高清日韩| 日韩午夜在线视频| 亚洲精品小视频在线观看| 母乳一区在线观看| 免费日韩av| 最近中文字幕日韩精品| 免费欧美网站| 亚洲精品自在久久| 亚洲在线网站| 国产视频在线观看一区二区| 久久99在线观看| 91久久国产自产拍夜夜嗨| 亚洲视频一区| 国产老女人精品毛片久久| 日韩视频在线观看免费| 亚洲一区亚洲| 亚洲第一福利在线观看| 欧美大片在线观看一区二区| 亚洲黄色小视频| 欧美一区二区在线| 亚洲国产精品成人一区二区 | 久久网站免费| 一区二区三区四区蜜桃| 国产婷婷一区二区|