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

            Why so serious? --[NKU]schindlerlee

            pku2367 拓?fù)渑判颍龅娜撕苌俚暮?jiǎn)單題。

            schindlerlee原創(chuàng),禁止轉(zhuǎn)載和用于商業(yè)用途

            邊看 見(jiàn)過(guò)大爺 邊寫竟然5分鐘不到秒了~
            拓?fù)渑判蛴袃煞N做法,一種是不斷找入度為0的點(diǎn),然后刪點(diǎn)和關(guān)聯(lián)的邊,一種是利用dfs退棧的順序
            如下:
             1 /* 
             2  * SOUR:pku 2367
             3  * ALGO:top sort
             4  * DATE: Mon, 12 Oct 2009 00:56:07 +0800
             5  * COMM:2
             6  * */
             7 #include<iostream>
             8 #include<cstdio>
             9 #include<cstdlib>
            10 #include<cstring>
            11 #include<algorithm>
            12 #include<vector>
            13 using namespace std;
            14 typedef long long LL;
            15 const int maxint = 0x7fffffff;
            16 const long long max64 = 0x7fffffffffffffffll;
            17 #define pr(x) fprintf(stderr, x)
            18 /* #define pr(x) for(;0;) */
            19 const int N = 128;
            20 vector < int >g[N];
            21 int dfn[N], n, vis[N], st[N], top;
            22 
            23 void dfs(int u)
            24 {
            25     if (vis[u]) return;
            26     vis[u] = true;
            27     for (int i = 0; i < g[u].size(); i++) {
            28         dfs(g[u][i]);
            29     }
            30     st[top++= u;
            31 }
            32 
            33 int main()
            34 {
            35     int i, j, k, u, v;
            36     scanf("%d"&n);
            37     for (u = 1; u <= n; u++) {
            38         while (1) {
            39             scanf("%d"&v);
            40             if (0 == v)
            41                 break;
            42             g[u].push_back(v);
            43         }
            44     }
            45     for (u = 1; u <= n; u++) {
            46         if (!vis[u]) {
            47             dfs(u);
            48         }
            49     }
            50     for (i = top - 1; i > 0; i--) {
            51         printf("%d ", st[i]);
            52     }
            53     printf("%d\n", st[i]);
            54     return 0;
            55 }
            56 

            當(dāng)出現(xiàn)環(huán)時(shí),找入度為0的方法顯然當(dāng)不能找到入度為0的點(diǎn)時(shí)且還有剩余點(diǎn)則有環(huán)
            利用dfs的方法就是找搜索樹(shù)種的回邊,利用染色的方法,算法導(dǎo)論上有介紹
            我寫的代碼如下:

            初始化:memset(vis,0,sizeof(vis));
            對(duì)所有vis[i] == 0,調(diào)用dfs
            bool dfs(int u)
            {
                if(vis[u] == 1) return false;
                if(vis[u] == 2) return true;
                vis[u] = 1;
                for(i = 0;i < g[u].size();i++) {
                    if(false == dfs(g[u][i])) {
                        return false;
                    }
                }
                vis[u] = 2;
                stack[top++] = u;
                return true;
            }
            下圖描述了dfs的過(guò)程,建議仔細(xì)體會(huì)一下,求圖的割點(diǎn),橋,LCA的 tarjen算法主要過(guò)程基本和此dfs過(guò)程非常相似
            圖中白色是還未訪問(wèn)的,黑色是已經(jīng)完全訪問(wèn)過(guò)的,藍(lán)色的是正在訪問(wèn)的


            posted on 2009-10-13 15:41 schindlerlee 閱讀(1290) 評(píng)論(1)  編輯 收藏 引用 所屬分類: 解題報(bào)告

            Feedback

            # re: pku2367 拓?fù)渑判颍龅娜撕苌俚暮?jiǎn)單題。 2009-10-14 16:37 99書城

            分享了~不錯(cuò)!  回復(fù)  更多評(píng)論   

            91久久精品电影| 亚洲欧美一级久久精品| 精品国产91久久久久久久a| 久久久久久亚洲精品不卡| 日韩精品久久久肉伦网站| 精品久久久无码中文字幕| 亚洲精品第一综合99久久| 91精品国产高清久久久久久io| 久久午夜羞羞影院免费观看| 久久无码人妻精品一区二区三区| 欧美大香线蕉线伊人久久| 久久ww精品w免费人成| 亚洲AV日韩AV永久无码久久| 国产成人久久777777| 成人综合伊人五月婷久久| 色偷偷91久久综合噜噜噜噜 | 无码伊人66久久大杳蕉网站谷歌 | 久久精品亚洲男人的天堂| 精品国产乱码久久久久软件| 91精品日韩人妻无码久久不卡 | 大伊人青草狠狠久久| 久久精品亚洲欧美日韩久久| 18岁日韩内射颜射午夜久久成人| 一本色道久久88综合日韩精品 | 久久久不卡国产精品一区二区| 2019久久久高清456| 91久久精品国产91性色也| 狠狠色丁香久久婷婷综合蜜芽五月 | 国产女人aaa级久久久级| 久久久久亚洲精品天堂| 久久国产成人精品国产成人亚洲| 狠狠色婷婷综合天天久久丁香| 欧美大香线蕉线伊人久久| 久久精品国产99国产精偷| 日本久久久久亚洲中字幕| 老男人久久青草av高清| 亚洲午夜福利精品久久| 亚洲国产精品成人AV无码久久综合影院| 日本精品久久久中文字幕 | 国内精品久久久久久中文字幕| 国产成人久久精品激情|