• <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>
            算法學(xué)社
            記錄難忘的征途
            posts - 141,comments - 220,trackbacks - 0
            題目描述:
               給一個(gè)(N<10,000)的有向無(wú)環(huán)圖,有M個(gè)物體坐落在若干個(gè)點(diǎn)上。A和B每次可以將某物體沿著某條邊移動(dòng)一次。多個(gè)物體可以重合。不能移動(dòng)者算輸。
            算法分析:
               SG定理,可以先拓?fù)渑判蛉缓笤賁G。
             1 #include<algorithm>
             2 #include<cstdio>
             3 #include<iostream>
             4 #include<bitset>
             5 using namespace std;
             6 int n,m;
             7 const int N = 10005;
             8 const int M = 100005;
             9 int head[N],nxt[M],pnt[M],e,dp[N];
            10 inline void add(int u,int v){
            11     nxt[e] = head[u]; head[u] = e; pnt[e++] = v;
            12 }
            13 struct node{int id,pre;} tmp[N];
            14 int tim,vis[N];
            15 void dfs(int u){
            16     vis[u] =1;
            17     for(int i = head[u]; i!= -1; i=nxt[i]){
            18         if(!vis[pnt[i]]) dfs(pnt[i]);
            19     }
            20     tmp[u].id = u;
            21     tmp[u].pre=tim++;
            22 }
            23 bool cmp(node a,node b){return a.pre < b.pre;}
            24 void process(){
            25     tim =0;
            26     for(int i = 1; i <= n; i++) vis[i] = 0;
            27     for(int i = 1; i <= n; i++) if(!vis[i]) dfs(i);
            28     sort(tmp+1,tmp+n+1,cmp);
            29     bitset<2*N> mp;
            30     for(int p = 1; p <= n; p++) {
            31         int u = tmp[p].id;
            32         mp.reset();
            33         for(int i = head[u]; i!=-1; i=nxt[i]){
            34             int v = pnt[i];
            35             mp[dp[v]] = 1;
            36         }
            37         for(int i = 0; i < mp.size(); i++) if(!mp[i]){
            38             dp[u] = i;
            39             break;
            40         }
            41     }
            42 }
            43 int main(){
            44     int ctest = 1;
            45     while(scanf("%d",&n)!=EOF){
            46         for(int i = 1; i <= n; i++) head[i] = -1;
            47         e = 0;
            48         for(int i = 1; i < n; i++ ){
            49             int t,v;
            50             scanf("%d",&t);
            51             while(t--){
            52                 scanf("%d",&v);
            53                 add(i,v);
            54             }
            55         }
            56         process();
            57         int t; scanf("%d",&t);
            58         printf("Case %d:\n",ctest++);
            59         while(t--){
            60             int val = 0,c,v;
            61             scanf("%d",&c);
            62             while(c--) {
            63                 scanf("%d",&v);
            64                 val ^= dp[v];
            65             }
            66             puts(val?"Alice":"Bob");
            67         }
            68     }
            69 }
            70 
            posted on 2012-12-23 14:04 西月弦 閱讀(420) 評(píng)論(0)  編輯 收藏 引用

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            老司机国内精品久久久久| 亚洲?V乱码久久精品蜜桃| 97精品久久天干天天天按摩| 亚洲国产美女精品久久久久∴| 一本色道久久综合狠狠躁| 色综合久久88色综合天天| 国产精品久久久久久五月尺| 无码人妻久久久一区二区三区 | 国产亚洲美女精品久久久| 亚洲国产精品综合久久网络| 国产精品99久久免费观看| 性做久久久久久久久浪潮| 久久99国内精品自在现线| 综合久久给合久久狠狠狠97色| 天天躁日日躁狠狠久久| 久久www免费人成精品香蕉| 久久男人Av资源网站无码软件| 色综合合久久天天给综看| 久久99国产精品二区不卡| 亚洲中文字幕久久精品无码APP| a级毛片无码兔费真人久久| 麻豆一区二区99久久久久| 久久婷婷色综合一区二区| 精品无码久久久久久国产| 久久午夜伦鲁片免费无码| 麻豆精品久久久久久久99蜜桃| 国产成人精品久久综合| 99久久精品国产高清一区二区| 久久精品国产久精国产一老狼| 久久一区二区三区免费| 狠狠色综合网站久久久久久久| 国产成年无码久久久久毛片| 亚洲国产精品无码久久一区二区| 精品国产婷婷久久久| 99久久精品免费国产大片| 精品九九久久国内精品| 国产精品久久国产精麻豆99网站| 久久99精品久久久久久动态图 | 人妻精品久久无码专区精东影业 | 精品免费tv久久久久久久| 大伊人青草狠狠久久|