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

算法學社
記錄難忘的征途
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>
            国产在线观看一区| 欧美在线在线| 一区二区三区福利| 亚洲国产一区二区视频| 欧美激情综合| 亚洲欧洲一区二区三区| 国产专区精品视频| 国语对白精品一区二区| 精品动漫3d一区二区三区| 韩国一区二区三区美女美女秀| 国产在线视频欧美| 在线观看一区欧美| 一区二区精品在线观看| 亚洲天堂黄色| 久久躁日日躁aaaaxxxx| 欧美激情一区二区三区在线视频 | 亚洲欧美国产日韩中文字幕| 午夜激情久久久| 久久人人爽人人爽| 亚洲高清av在线| 亚洲一区二区在线免费观看视频| 亚洲欧美中文字幕| 欧美+亚洲+精品+三区| 欧美视频免费在线| 亚洲电影免费| 亚洲一区欧美激情| 欧美大片免费观看| 亚洲已满18点击进入久久| 久久精品日韩欧美| 欧美日韩中字| 一区二区在线视频观看| 一区二区三区欧美在线观看| 久久全球大尺度高清视频| 亚洲欧洲精品一区二区三区| 亚洲欧美一区二区三区极速播放 | 麻豆av一区二区三区久久| 亚洲欧洲一区二区天堂久久| 欧美影院精品一区| 欧美日韩一级视频| 狠狠操狠狠色综合网| 亚洲一二三区在线观看| 欧美二区在线观看| 欧美在线观看视频在线| 欧美日本精品一区二区三区| 一区视频在线播放| 久久精品国产欧美激情| 亚洲黄色成人网| 欧美一区二区三区在线免费观看| 亚洲欧美日韩电影| 国产精品狠色婷| 亚洲精品一线二线三线无人区| 久久精品夜色噜噜亚洲a∨ | 亚洲人成在线观看一区二区| 久久综合久久久| 午夜一区二区三视频在线观看| 国产精品国产三级国产专区53| 99在线精品观看| 亚洲人成久久| 欧美精品激情| 日韩一级网站| 亚洲精品在线看| 欧美日韩免费在线| 亚洲午夜一区二区| 在线亚洲精品福利网址导航| 欧美三级电影一区| 亚洲综合999| 亚洲欧美中文日韩在线| 国产欧美 在线欧美| 欧美中文在线观看国产| 欧美在线亚洲一区| 又紧又大又爽精品一区二区| 欧美aaaaaaaa牛牛影院| 免费看亚洲片| 亚洲精品视频在线| 欧美激情一区二区三区在线视频| 欧美成人tv| 亚洲视频精品| 亚洲欧美伊人| 欧美视频在线观看 亚洲欧| 欧美在线播放高清精品| 国产日韩欧美一区二区三区在线观看 | 999亚洲国产精| 亚洲欧洲一级| 国产精品女同互慰在线看| 久久精品视频一| 久久精品视频播放| 亚洲精品在线二区| 亚洲影院色无极综合| 韩国三级电影一区二区| 亚洲国产欧美不卡在线观看| 欧美性色aⅴ视频一区日韩精品| 欧美一级片久久久久久久| 久久久久久有精品国产| 夜夜精品视频| 欧美一二三视频| 亚洲日韩欧美一区二区在线| 亚洲视频二区| 亚洲黄网站在线观看| 亚洲视频高清| 亚洲国产精品一区制服丝袜| 一本久道久久久| 国产精品v欧美精品v日本精品动漫| 国产精品伦理| 欧美成人亚洲成人| 国产精品久久波多野结衣| 女人香蕉久久**毛片精品| 欧美视频在线观看一区| 欧美激情精品久久久| 国产伦精品一区二区三区视频黑人| 欧美大色视频| 国产视频一区在线| 99国内精品久久| 亚洲国产精彩中文乱码av在线播放| 亚洲视频第一页| 99这里只有精品| 久久九九久久九九| 午夜亚洲伦理| 欧美日韩综合另类| 亚洲国产毛片完整版| 激情五月***国产精品| 亚洲综合三区| 在线亚洲精品| 免费一区视频| 久久在线免费| 国产婷婷色综合av蜜臀av| av成人激情| 亚洲精品中文字幕在线| 久久噜噜噜精品国产亚洲综合| 欧美一区二区成人6969| 国产精品九色蝌蚪自拍| 亚洲激情午夜| 91久久国产综合久久91精品网站| 欧美一区亚洲| 久久免费国产精品| 狠狠综合久久av一区二区小说 | 在线观看福利一区| 久久精品国产99| 久久久久网址| 国产一区二区三区免费在线观看| 亚洲视频网站在线观看| 亚洲自拍偷拍一区| 国产精品一区视频网站| 亚洲专区一二三| 久久精品国产69国产精品亚洲| 国产美女精品免费电影| 亚洲欧美成人综合| 久久成人这里只有精品| 国产一区日韩一区| 久久精品99国产精品日本| 久久中文字幕一区| 亚洲黄色天堂| 欧美日韩一区免费| 亚洲欧美日韩在线| 美女久久一区| 亚洲美女在线一区| 欧美性做爰猛烈叫床潮| 亚洲少妇在线| 久久精品五月| 亚洲精品1区2区| 国产精品久久久91| 羞羞漫画18久久大片| 狂野欧美激情性xxxx| 亚洲日本成人网| 国产精品黄页免费高清在线观看| 亚洲欧美日韩在线高清直播| 久久久www成人免费毛片麻豆| 精品电影在线观看| 亚洲综合色丁香婷婷六月图片| 欧美激情第五页| 亚洲精品久久久久| 亚洲欧美综合另类中字| 国产一区二区三区久久悠悠色av| 欧美**人妖| 午夜精品一区二区三区电影天堂| 久久久久欧美精品| 一区二区三区四区五区在线| 国产精品视频第一区| 久久久午夜视频| 亚洲人成网站在线观看播放| 午夜久久影院| 在线观看亚洲视频啊啊啊啊| 欧美日韩亚洲天堂| 亚洲欧美高清| 亚洲区一区二| 国产精品毛片大码女人| 久久综合九九| 亚洲深爱激情| 亚洲人成7777| 麻豆成人在线| 欧美在线三区| 中文精品一区二区三区| 黄色日韩网站视频| 国产精品中文在线| 欧美日韩国产三级| 久久综合狠狠综合久久综青草| 亚洲一区二区精品视频| 亚洲全部视频| 亚洲国产精品一区二区第一页 | 亚洲国产精品第一区二区三区| 国产精品亚洲成人|