• <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

            隊友

            技術

            朋友

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            亚洲欧美日韩精品久久| 国内精品久久久久影院薰衣草| 久久精品国产网红主播| 国产午夜久久影院| 亚洲&#228;v永久无码精品天堂久久 | 婷婷久久五月天| 伊人久久大香线蕉av不卡| 2021精品国产综合久久| 久久一本综合| 狠狠色丁香婷婷久久综合不卡| 亚洲综合久久综合激情久久 | 狠狠色丁香久久婷婷综合_中| 亚洲熟妇无码另类久久久| 亚洲国产成人久久精品动漫| 国产精品亚洲综合久久| 精品国产福利久久久| 欧美粉嫩小泬久久久久久久 | 一本久久a久久精品亚洲| 韩国三级大全久久网站| 热久久最新网站获取| 91久久国产视频| 精品国产乱码久久久久久1区2区| 久久影院亚洲一区| 久久激情五月丁香伊人| 久久香蕉综合色一综合色88| 日产精品久久久一区二区| 日本精品久久久久久久久免费| 久久久久久狠狠丁香| 国产精品福利一区二区久久| 久久精品国产精品亚洲精品| 久久久久久A亚洲欧洲AV冫| 色综合久久久久网| 欧美亚洲国产精品久久蜜芽| 97超级碰碰碰久久久久| 久久亚洲欧美国产精品| 国产69精品久久久久久人妻精品| 久久亚洲精品国产精品婷婷| 国产免费久久精品99久久| 大美女久久久久久j久久| 麻豆精品久久久一区二区| 久久99久久99小草精品免视看|