• <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>
            我叫張小黑
            張小黑的掙扎生活
            posts - 66,  comments - 109,  trackbacks - 0

             

             1 //并查集
             2 #include<iostream>
             3 #define MaxN 100000
             4 typedef struct{
             5     int fparent;
             6     int frank;
             7     int others;
             8 }NODE;
             9 NODE S[MaxN+1];
            10 void init(int n)
            11 {
            12     for(int i=1;i<=n;i++){
            13         S[i].fparent=i;
            14         S[i].frank=0;
            15         S[i].others=-1;
            16     }
            17 }
            18 int find_set(int x)
            19 {
            20     if(x==-1)return -1;
            21     if(S[x].fparent!=x)
            22         S[x].fparent=find_set(S[x].fparent);
            23     return S[x].fparent;
            24 }
            25 int union_set(int x,int y)
            26 {
            27     if(x==-1)return y;
            28     if(y==-1)return x;
            29     if(S[x].frank>S[y].frank)
            30     {
            31         S[y].fparent=x;
            32         return x;
            33     }
            34     else {
            35         S[x].fparent=y;
            36         if(S[x].frank==S[y].frank)
            37             S[y].frank++;
            38         return y;
            39     }
            40 }
            41 void make(int x,int y)//is the enemy of y
            42 {
            43     int tx,ty;
            44     x=find_set(x);
            45     y=find_set(y);
            46     tx=union_set(S[x].others,y);//這是x敵人團伙的合并,也是y朋友團伙的合并,對于y來說x的敵人也是y的朋友
            47                                 //tx是x敵人團伙合并后新的頭,y朋友團伙合并后新的頭
            48     ty=union_set(x,S[y].others);//這是y敵人團伙的合并,也是x朋友團伙的合并,對于x來說y的敵人也是x的朋友
            49                                 //ty是y敵人團伙合并后新的頭,x朋友團伙合并后新的頭
            50     S[tx].others=ty;//注意union_set返回的永遠是頭
            51     S[ty].others=tx;
            52 }
            53 int main()
            54 {
            55     int T,N,M,i,p,q;
            56     char X;
            57     scanf("%d",&T);
            58     while(T>0){
            59         T--;
            60         scanf("%d%d",&N,&M);
            61         getchar();
            62         init(N);
            63         for(i=0;i<M;i++){
            64             scanf("%c %d %d",&X,&p,&q);
            65             getchar();
            66             if(X=='A'){
            67                 p=find_set(p);
            68                 q=find_set(q);
            69                 if(p==q)printf("In the same gang.\n");
            70                 else if(p==S[q].others)printf("In different gangs.\n");
            71                 else printf("Not sure yet.\n");}
            72             else if(X=='D')
            73                 make(p,q);
            74         }
            75     }
            76     return 0;
            77 }
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1703
            posted on 2008-01-27 15:55 zoyi 閱讀(463) 評論(0)  編輯 收藏 引用
            歡迎光臨 我的白菜菜園

            <2009年8月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            常用鏈接

            留言簿(8)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊

            acmer

            online judge

            隊友

            技術

            朋友

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲嫩草影院久久精品| 久久久精品视频免费观看 | 一级a性色生活片久久无| 欧美日韩中文字幕久久久不卡| 久久精品国产亚洲av瑜伽| 国产精品成人久久久| 青青草原综合久久大伊人精品| 色偷偷88欧美精品久久久| 久久久久久人妻无码| 久久精品成人一区二区三区| 青青草原综合久久大伊人| 91亚洲国产成人久久精品| 欧美精品九九99久久在观看| 国产午夜精品久久久久免费视 | 伊人久久免费视频| 久久婷婷五月综合国产尤物app| 久久精品人人做人人爽电影| 久久久久久久波多野结衣高潮 | 欧美粉嫩小泬久久久久久久 | 午夜精品久久久久久久无码| 久久国产精品成人影院| 久久久国产亚洲精品| 国产精品亚洲综合专区片高清久久久| 久久偷看各类wc女厕嘘嘘| 久久WWW免费人成一看片| 国产真实乱对白精彩久久| 久久国产精品-久久精品| 久久精品无码专区免费青青| 伊人久久大香线蕉av不卡| 无码8090精品久久一区| 久久人人爽人人精品视频| 国产精品成人久久久久三级午夜电影| 午夜人妻久久久久久久久| 精品熟女少妇AV免费久久 | 99久久久国产精品免费无卡顿| 午夜精品久久久久久影视riav| 久久精品一区二区三区中文字幕| 色综合久久综精品| 久久青青国产| 久久精品国产亚洲AV久| 欧美牲交A欧牲交aⅴ久久|