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

            糯米

            TI DaVinci, gstreamer, ffmpeg
            隨筆 - 167, 文章 - 0, 評(píng)論 - 47, 引用 - 0
            數(shù)據(jù)加載中……

            POJ 3123 Ticket to Ride 動(dòng)態(tài)規(guī)劃+Minimal Steiner Tree

            這題絕對(duì)不是蓋的。
            題目大意是:
            給出一個(gè)無(wú)向圖,和四對(duì)數(shù)據(jù)。每對(duì)數(shù)據(jù)分別為圖中的兩個(gè)點(diǎn)。
            要求添加一些邊,使每對(duì)點(diǎn)都能連通,讓總邊權(quán)最小。

            首先考慮一個(gè)子問(wèn)題:指定一些點(diǎn),添加一些邊,讓它們連通,并且總邊權(quán)最小。
            這個(gè)問(wèn)題就是Minimal Steiner Tree問(wèn)題,解決方法可以見(jiàn)這里
            這問(wèn)題不是蓋的,它居然是NP完全問(wèn)題。。
            汗。。今天終于在POJ見(jiàn)識(shí)到啥叫NP完全問(wèn)題了。。

            大的問(wèn)題可以分為多個(gè)子問(wèn)題。可以枚舉所有pair的連接狀況。
            比如說(shuō) {1和2鏈接,3和4鏈接} 或者 {1獨(dú)立,2獨(dú)立,3和4鏈接} 等等
            一共有15種情況。分別為
                // 1,1,1,1
                {{1},{2},{3},{4}},
                // 1,1,2
                {{1,2},{3},{4}},
                {{1,3},{2},{4}},
                {{1,4},{2},{3}},
                {{2,3},{1},{4}},
                {{2,4},{1},{3}},
                {{3,4},{1},{2}},
                // 2,2
                {{1,2},{3,4}},
                {{1,3},{2,4}},
                {{1,4},{2,3}},
                // 1,3
                {{1,2,3},{4}},
                {{1,2,4},{3}},
                {{1,3,4},{2}},
                {{2,3,4},{1}},
                // 4
                {{1,2,3,4}},

            其中有一些是重復(fù)的,就可以開(kāi)一個(gè)數(shù)組保存下來(lái)。
            貼一個(gè)我的程序。當(dāng)然,這個(gè)是TLE的。。官方的數(shù)據(jù)需要將近一分鐘才能跑完。
            另外一個(gè)標(biāo)程運(yùn)行飛快,用得是更好的方法,點(diǎn)這里


            #include <stdio.h>
            #include 
            <string.h>
            #include 
            <algorithm>
            #include 
            <cmath>

            using namespace std;

            char names[32][32];
            int N, M;
            int W[32][32];
            const int INF = 10032*32;
            int pairs[4];
            int dp[256][2], dn;

            int getcity(char *s)
            {
                
            int i;
                
            for (i = 0; i < N; i++)
                    
            if (!strcmp(s, names[i]))
                        
            break;
                
            return i;
            }

            int prim(int mask)
            {
                
            int i, j, mc, mi, a, c, t;

                c 
            = 0;
                
            for (i = 0; i < N; i++
                    
            if (mask & (1 << i)) {
                        a 
            = 1 << i;
                        c
            ++;
                    }

                t 
            = 0;
                
            while (--c) {
                    mc 
            = INF;
                    
            for (i = 0; i < N; i++)
                        
            if (a & (1 << i)) 
                            
            for (j = 0; j < N; j++)
                                
            if (((mask ^ a) & (1 << j)) && W[i][j] < mc) {
                                    mc 
            = W[i][j];
                                    mi 
            = j;
                                }
                    
            if (mc == INF)
                        
            return INF;
                    a 
            |= 1 << mi;
                    t 
            += mc;
                }

                
            return t;
            }

            int K;

            int dfs(int start, int mask, int n)
            {
                
            int i, r;

                
            if (n >= K - 2)
                    
            return prim(mask);
                
                r 
            = prim(mask);
                
            for (i = start; i < N; i++
                    
            if ((1 << i) & ~mask) 
                        r 
            = min(r, dfs(i+1, mask|(1<<i), n+1));

                
            return r;
            }

            int minicost(int mask)
            {
                
            int i, r;

                
            for (i = 0; i < dn; i++)
                    
            if (mask == dp[i][0])
                        
            return dp[i][1];

                K 
            = 0;
                
            for (i = 0; i < N; i++)
                    
            if (mask & (1 << i))
                        K
            ++;
                
                r 
            = dfs(0, mask, 0);

                dp[dn][
            0= mask;
                dp[dn][
            1= r;
                dn
            ++;
                
            return r;
            }

            int stats[15][8][8= {
                
            // 1,1,1,1
                {{1},{2},{3},{4}},
                
            // 1,1,2
                {{1,2},{3},{4}},
                {{
            1,3},{2},{4}},
                {{
            1,4},{2},{3}},
                {{
            2,3},{1},{4}},
                {{
            2,4},{1},{3}},
                {{
            3,4},{1},{2}},
                
            // 2,2
                {{1,2},{3,4}},
                {{
            1,3},{2,4}},
                {{
            1,4},{2,3}},
                
            // 1,3
                {{1,2,3},{4}},
                {{
            1,2,4},{3}},
                {{
            1,3,4},{2}},
                {{
            2,3,4},{1}},
                
            // 4
                {{1,2,3,4}},
            };

            int main()
            {
                
            int i, j, k, a, b, c, ans;
                
            char sa[32], sb[32];

                
            while (scanf("%d%d"&N, &M), N) {
                    
            for (i = 0; i < N; i++)
                        scanf(
            "%s", names[i]);
                    
            for (i = 0; i < N; i++)
                        
            for (j = 0; j < N; j++)
                            W[i][j] 
            = INF;
                    
            for (i = 0; i < M; i++) {
                        scanf(
            "%s%s%d", sa, sb, &c);
                        a 
            = getcity(sa);
                        b 
            = getcity(sb);
                        W[a][b] 
            = W[b][a] = min(W[a][b], c);
                    }
                    
            for (i = 0; i < 4; i++) {
                        scanf(
            "%s%s", sa, sb);
                        a 
            = getcity(sa);
                        b 
            = getcity(sb);
                        pairs[i] 
            = (1 << a) | (1 << b);
                    }

                    
            // floyd
                    for (k = 0; k < N; k++)
                        
            for (i = 0; i < N; i++)
                            
            for (j = 0; j < N; j++)
                                W[i][j] 
            = min(W[i][k] + W[k][j], W[i][j]);

                    dn 
            = 0;
                    ans 
            = INF;
                    
            for (i = 0; i < 15; i++) {
                        c 
            = 0;
                        
            for (j = 0; stats[i][j][0]; j++) {
                            a 
            = 0;
                            
            for (k = 0; stats[i][j][k]; k++)
                                a 
            |= pairs[stats[i][j][k] - 1];
                            c 
            += minicost(a);
                        }
                        ans 
            = min(ans, c);
                    }

                    printf(
            "%d\n", ans);
                }
                
            return 0;
            }



             

            posted on 2011-02-24 00:44 糯米 閱讀(1092) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): POJ

            久久狠狠高潮亚洲精品| 久久综合久久久| 亚洲国产美女精品久久久久∴| 久久久久AV综合网成人| 天天综合久久久网| 国产亚洲美女精品久久久2020| 99久久免费国产特黄| 香蕉久久夜色精品国产尤物| 久久亚洲春色中文字幕久久久 | 久久久久亚洲AV无码去区首| 国内精品人妻无码久久久影院导航| 四虎国产精品免费久久5151| 久久人人爽人人人人片av| 久久99精品国产麻豆蜜芽| 看久久久久久a级毛片| 怡红院日本一道日本久久 | 久久性生大片免费观看性| 久久久久久无码Av成人影院| 亚洲国产成人久久一区久久| 欧美亚洲另类久久综合| 伊人久久大香线蕉av一区| 久久国产综合精品五月天| 久久精品aⅴ无码中文字字幕重口| 亚洲国产精品成人久久蜜臀 | 久久久久av无码免费网| 久久久久久噜噜精品免费直播| 精品熟女少妇a∨免费久久| 日本WV一本一道久久香蕉| 久久亚洲色一区二区三区| 99久久精品无码一区二区毛片 | 久久精品日日躁夜夜躁欧美| 日韩va亚洲va欧美va久久| 久久国产视屏| 精品免费久久久久国产一区| 久久亚洲国产午夜精品理论片| AV狠狠色丁香婷婷综合久久| 国产精品女同久久久久电影院| 久久精品国产99久久久| 久久国产欧美日韩精品| 99久久人妻无码精品系列| 2020久久精品国产免费|