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

算法學社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
題目描述:
   平面上有N<300個點。每個兩個點如果距離小于R且之間沒有共線的另一個點,則這兩點之間有一條邊。求這個圖的生成樹的個數mod 10007。

算法分析:
   用O(N*NlogN)的方法建圖。即枚舉每個點然后極角排序來判斷是否存在共線的點。
   
   建圖之后的任務是統計生成樹的個數,方法是求這個圖的Krichhoof矩陣的n-1主行列式的值。
   Krichhoof矩陣G是這樣的:
      Gii等于點i的度數
      當i和j有邊時,Gij = -1。否則Gij等于0。
   
   然后行列式求值。方法是高斯消元求上三角陣。行列式的值等于對角線元素的積。
   由于是整數然后再mod。我們再消元時需要求最小公倍數。還需要拓展歐幾里得算法求逆元。
   總之是比較綜合的一道好題。

#include<iostream>
#include<algorithm>
#include<cassert>
#include<cstdio>
#include<complex>
#include<cmath>
using namespace std;
// geometry
const double eps = 1e-9;
const int N = 300 + 10;
#define X real
#define Y imag
typedef complex <double> pnt;
pnt num[N];
static double cross (const pnt &a, const pnt &b) { return Y(conj(a) * b);}
pair <double,int> hash[N];
int tp;
bool cmp(const pair<double,int> &a , const pair<double,int> &b){
    #define  ff first
    #define  ss second
    return (a.ff - b.ff) < eps ? abs(num[a.ss] - num[tp]) < abs(num[b.ss] - num[tp]): a.ff < b.ff;
}
// lcm
const int mod = 10007;
int G[N][N],vis[N];
int gcd(int a,int b) { return b ? gcd(b , a%b) : a;}
int lcm(int a,int b){
    return a * b / gcd(a,b);
}
// exgcd
int res[mod];
void exgcd(int a,int b,int &x,int &y){
    if( b== 0) {
        x = 1; y = 0; return ;
    }
    exgcd(b, a%b, x, y);
    int t = y; y = x - a/b*y; x = t;
}
int cal_res(int v) {
    int x, y;
    exgcd(v, mod, x, y);
    return (x + mod) % mod;
}
// main
int main(){
    int test;
    cin >> test ;
    for(int i=1;i<mod;i++) res[i] = cal_res(i);
    while(test -- ){
        int n,r;
        scanf("%d%d",&n,&r);
        for(int i=0;i<n;i++){
            int x,y;
            scanf("%d%d",&x,&y);
            num[i] = pnt(x,y);
        }
        for(int i=0;i<n;i++) for(int j=0;j<n;j++) G[i][j] = 0;
        for(tp=0;tp<n;tp++) {
            int len = 0;
            for(int j=0; j< n;j ++) if(tp != j) 
                hash[len ++] = make_pair(arg(num[j] - num[tp]),j);
            sort(hash, hash + len);
            for(int j=0; j<len; j++) if(!j || abs(hash[j].first - hash[j-1].first) > eps) {
                int v = hash[j].second;
                if(abs(num[tp] - num[v]) < r + eps){
                    G[tp][v] = mod - 1;
                    G[tp][tp] ++;
                }
            }
        }
        // gauss
        n --;
        int ans = 1;
        for(int i=0;i<n;i++) vis[i] = 0;
        for(int i=0;i<n;i++) {
            int s = -1;
            for(int j=0;j<n;j++) if(!vis[j] && G[j][i]){
                s = j; break;
            }
            if(s == -1) {
                ans = 0;
                break;
            }
            ans = (ans * G[s][i]) % mod;
            vis[s] = 1;
            for(int j=0;j<n;j++) if(!vis[j] && G[j][i]) {
                int c = lcm(G[j][i], G[s][i]);
                int t = c / G[j][i];
                int p = c / G[s][i];
                assert(t < mod);
                ans = (ans * res[t]) % mod;
                for(int k = i; k< n; k++) {
                    G[j][k] = (G[j][k] * t - G[s][k] * p) % mod;
                    G[j][k] = (G[j][k] + mod) % mod;
                }
            }
        }
        cout << (ans == 0 ? -1 : ans) << endl;
    }
}
posted on 2012-07-29 22:29 西月弦 閱讀(450) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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精品福利视频| 亚洲神马久久| 久久se精品一区精品二区| 久久精品72免费观看| 久热精品视频在线观看| 欧美超级免费视 在线| 欧美成人一区在线| 欧美先锋影音| 狠狠色噜噜狠狠色综合久| 亚洲大胆视频| 亚洲图片欧美日产| 久久久久看片| 亚洲国产成人不卡| 这里是久久伊人| 久久精品2019中文字幕| 欧美久久久久| 国精产品99永久一区一区| 亚洲巨乳在线| 久久久91精品| 一区二区三欧美| 麻豆久久婷婷| 国产精品专区第二| 亚洲国产精品一区二区久| 亚洲资源av| 欧美福利视频在线观看| 亚洲一区二区视频| 欧美激情四色| 在线日韩中文字幕| 久久精品视频在线看| 99精品视频网| 欧美激情 亚洲a∨综合| 国际精品欧美精品| 性久久久久久久久| 亚洲乱亚洲高清| 美女精品自拍一二三四| 国产小视频国产精品| 亚洲欧美日韩国产一区二区| 亚洲国产精品一区二区第一页 | 国产精品www994| 精品91视频| 久久精品亚洲一区二区| 一区二区三区视频在线播放| 欧美成在线视频| 在线观看日韩精品| 久久久综合激的五月天| 亚洲欧美日韩精品久久奇米色影视 | 亚洲欧美在线免费| 国产精品久久久久aaaa九色| 日韩亚洲欧美一区二区三区| 另类酷文…触手系列精品集v1小说| 在线综合欧美| 国产精品sm| 亚洲欧美中文日韩v在线观看| 亚洲美女黄色| 欧美日韩综合网| 亚洲视频自拍偷拍| 一区二区久久久久久| 欧美视频免费| 午夜影视日本亚洲欧洲精品| 亚洲午夜免费福利视频| 国产精品海角社区在线观看| 亚洲欧美日本国产有色| 亚洲欧美成人在线| 国产主播一区二区| 欧美成人一区二区三区在线观看| 噜噜噜躁狠狠躁狠狠精品视频| 1000部国产精品成人观看| 欧美成人午夜剧场免费观看| 欧美成人综合网站| 亚洲综合日本| 久久都是精品| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲欧美亚洲| 国产曰批免费观看久久久| 久久裸体视频| 欧美1区免费| 亚洲图片在线观看| 亚洲永久精品国产| 激情国产一区二区| 91久久一区二区| 国产精品久久久久久一区二区三区| 欧美在线一二三四区| 久久一区二区视频| 亚洲天堂免费观看| 久久久久久久国产| 亚洲午夜影视影院在线观看| 亚洲欧美另类在线| 91久久精品国产91性色tv| 一本久久a久久精品亚洲| 国产在线欧美日韩| 亚洲免费观看高清在线观看 | av不卡在线| 狠狠色综合色区| 一区二区电影免费在线观看| 国产最新精品精品你懂的| 亚洲精品日产精品乱码不卡| 国产欧美一区二区精品婷婷| 欧美韩日一区二区| 国产日韩av高清| 亚洲免费观看高清在线观看| 激情伊人五月天久久综合| 日韩午夜在线观看视频| 影音欧美亚洲| 亚洲欧洲99久久| 一区二区三区四区蜜桃| 久久精品国内一区二区三区| 亚洲一区二区三区精品动漫| 女生裸体视频一区二区三区| 久久久久免费视频| 国产女精品视频网站免费| 亚洲国产视频一区二区| 国产亚洲激情视频在线| 亚洲深夜福利在线| 正在播放亚洲| 欧美女同在线视频| 欧美激情一区| 在线欧美亚洲| 久久久不卡网国产精品一区| 欧美一区二区三区精品电影| 欧美精品性视频| 亚洲第一区在线观看| 激情久久久久久久| 亚洲欧美日韩人成在线播放| 亚洲一区二区黄| 欧美电影在线播放| 免费成人小视频| 伊人夜夜躁av伊人久久| 久久精品国产99精品国产亚洲性色 | 国产精品久久久久久久久久免费看 | 最新日韩欧美| 亚洲精品资源美女情侣酒店| 老牛嫩草一区二区三区日本| 老司机67194精品线观看| 国产综合色在线| 久久精品亚洲| 裸体一区二区| 在线观看三级视频欧美| 久热精品视频在线| 亚洲国产精品久久久久婷婷老年| 亚洲欧洲日产国产综合网| 欧美成人高清视频| 亚洲裸体在线观看| 亚洲欧美另类国产| 国产日产高清欧美一区二区三区| 亚洲与欧洲av电影| 久久久久久久久岛国免费| 精品999网站| 欧美~级网站不卡| 亚洲最新合集| 久久久国际精品| 最新日韩av| 国产精品超碰97尤物18| 午夜亚洲视频| 欧美韩日视频| 午夜综合激情| 在线欧美视频| 欧美性jizz18性欧美| 性亚洲最疯狂xxxx高清| 欧美91视频| 亚洲一区二区三区在线视频| 国产日韩欧美在线播放| 蜜臀久久99精品久久久画质超高清| 亚洲国产精品一区在线观看不卡 | 日韩特黄影片| 欧美诱惑福利视频| 在线欧美亚洲| 国产精品hd| 久久久精彩视频| 亚洲靠逼com| 久久综合成人精品亚洲另类欧美| 91久久在线| 美国十次了思思久久精品导航| 国产欧美日韩精品a在线观看| 欧美在线视频观看| 91久久在线| 久久九九99视频| 一个色综合导航| 精品999日本| 国产精品美女久久久久久久| 久久久青草青青国产亚洲免观| 99国产精品国产精品久久| 久热re这里精品视频在线6| 亚洲午夜免费福利视频| 亚洲国产欧美在线人成| 国产日韩欧美在线播放| 国产精品国产三级国产专播精品人| 久久免费高清| 性一交一乱一区二区洋洋av| 在线视频精品| 99在线热播精品免费99热|