青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

糯米

TI DaVinci, gstreamer, ffmpeg
隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
數據加載中……

POJ 3123 Ticket to Ride 動態規劃+Minimal Steiner Tree

這題絕對不是蓋的。
題目大意是:
給出一個無向圖,和四對數據。每對數據分別為圖中的兩個點。
要求添加一些邊,使每對點都能連通,讓總邊權最小。

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

大的問題可以分為多個子問題。可以枚舉所有pair的連接狀況。
比如說 {1和2鏈接,3和4鏈接} 或者 {1獨立,2獨立,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}},

其中有一些是重復的,就可以開一個數組保存下來。
貼一個我的程序。當然,這個是TLE的。。官方的數據需要將近一分鐘才能跑完。
另外一個標程運行飛快,用得是更好的方法,點這里


#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 糯米 閱讀(1109) 評論(0)  編輯 收藏 引用 所屬分類: POJ

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美精品在线免费| 午夜欧美大片免费观看| 女仆av观看一区| 亚洲免费观看在线观看| 亚洲欧洲视频在线| 欧美日韩午夜在线视频| 亚洲永久免费av| 久久aⅴ乱码一区二区三区| 在线色欧美三级视频| 欧美大片一区二区三区| 欧美精品少妇一区二区三区| 亚洲深爱激情| 性做久久久久久免费观看欧美 | 亚洲视频久久| 国产色综合天天综合网| 欧美成ee人免费视频| 欧美理论在线| 久久精品国产99精品国产亚洲性色| 久久国产婷婷国产香蕉| 亚洲精选国产| 欧美一级在线亚洲天堂| 亚洲三级视频在线观看| 亚洲一区自拍| 亚洲精品乱码久久久久久按摩观 | 久久国产精品网站| 美女诱惑一区| 欧美亚洲网站| 麻豆成人小视频| 午夜精品婷婷| 欧美激情中文字幕乱码免费| 性18欧美另类| 欧美理论电影网| 免费美女久久99| 国产精品免费网站在线观看| 欧美xx69| 国产在线观看精品一区二区三区| 亚洲国产天堂久久综合| 国产视频自拍一区| 日韩天堂在线视频| 在线精品福利| 羞羞漫画18久久大片| 欧美电影免费观看高清| 欧美在线亚洲一区| 欧美日韩国产成人在线观看| 久久亚洲精品中文字幕冲田杏梨| 欧美性理论片在线观看片免费| 牛夜精品久久久久久久99黑人| 国产欧美日韩精品一区| 在线综合欧美| 亚洲色图综合久久| 欧美日韩国产精品专区 | 性做久久久久久久久| 欧美日精品一区视频| 亚洲国产精品va在线看黑人| 红桃视频成人| 久久精品国语| 久久综合综合久久综合| 国产美女一区二区| 亚洲欧美日韩精品久久久久| 亚洲欧美视频一区| 欧美三日本三级少妇三2023| 亚洲精品日产精品乱码不卡| 99精品国产99久久久久久福利| 欧美a级在线| 欧美激情偷拍| 一本色道久久| 国产精品黄视频| 午夜精品剧场| 久久久久网址| 亚洲国产日韩欧美在线99| 麻豆91精品| 亚洲免费av网站| 亚洲影院免费观看| 国产偷久久久精品专区| 久久久精品动漫| 亚洲国产岛国毛片在线| 亚洲伦理一区| 国产精品草草| 性欧美video另类hd性玩具| 久久性天堂网| 亚洲精品午夜| 欧美日一区二区三区在线观看国产免| 国产精品99久久久久久久久久久久| 亚洲免费在线视频| 国产亚洲精品v| 美女脱光内衣内裤视频久久影院 | 久久国产毛片| 亚洲激情第一页| 国产精品久久久久久妇女6080| 新67194成人永久网站| 久久露脸国产精品| 亚洲免费av片| 国产精品一区二区久久久久| 久久青草久久| 一区二区三区不卡视频在线观看| 欧美一区二区三区免费视| 极品少妇一区二区三区| 欧美破处大片在线视频| 午夜在线成人av| 亚洲韩日在线| 久久成人国产精品| 亚洲精品永久免费| 国产午夜久久久久| 欧美高清在线播放| 欧美综合国产| 亚洲日本激情| 久久综合狠狠综合久久激情| 亚洲视频1区| 欧美顶级少妇做爰| 亚洲女性喷水在线观看一区| 久久亚洲电影| 国产精品久久久久9999| 久久久久久久久久久久久久一区| 亚洲欧洲日本国产| 老司机精品视频网站| 亚洲欧美成人精品| 亚洲蜜桃精久久久久久久| 国产亚洲福利社区一区| 国产精品高潮呻吟久久av黑人| 久久久青草青青国产亚洲免观| 亚洲伊人伊色伊影伊综合网 | 夜夜嗨av一区二区三区四季av| 黄色日韩网站| 国产精品一区二区三区观看| 欧美视频福利| 欧美激情亚洲综合一区| 久久亚洲午夜电影| 午夜精品影院| 亚洲欧美日韩国产中文| 亚洲一区二区三区免费在线观看| 亚洲精品孕妇| 日韩一区二区精品在线观看| 亚洲国产欧美日韩| 欧美大片在线看免费观看| 久久视频在线看| 久久久爽爽爽美女图片| 久久久人成影片一区二区三区| 欧美在线视频免费观看| 午夜老司机精品| 亚洲欧美日韩精品一区二区| 亚洲影视九九影院在线观看| 亚洲视频一区二区在线观看| 一本大道久久a久久综合婷婷 | 国产一区二区三区观看| 国产日韩综合| 国产资源精品在线观看| 国产日韩三区| 一区二区视频在线观看| 在线观看福利一区| 亚洲国产黄色| 亚洲精品一区二区三区福利| 亚洲精品久久久久久久久久久久久| 亚洲精品视频一区二区三区| 在线亚洲一区二区| 亚洲免费视频一区二区| 销魂美女一区二区三区视频在线| 欧美一区二区三区在线看| 久久久久国色av免费观看性色| 久久嫩草精品久久久精品| 欧美黄色aaaa| 日韩视频在线观看国产| 亚洲网在线观看| 欧美一区二区三区播放老司机| 久久久久久久久久久久久女国产乱 | 欧美激情bt| 99这里只有久久精品视频| 亚洲图片在线观看| 久久久久国产精品厨房| 欧美成人久久| 国产精品毛片a∨一区二区三区|国 | 国产精品日韩在线播放| 激情综合五月天| 99国产成+人+综合+亚洲欧美| 亚洲一区二区三区精品在线观看 | 欧美精品日韩| 欧美日韩国产综合在线| 国产午夜精品麻豆| 亚洲第一在线视频| 亚洲欧美国产日韩中文字幕| 久久影院午夜论| 亚洲乱码一区二区| 久久久国产成人精品| 欧美日韩成人一区二区三区| 国产亚洲第一区| 国产精品99久久久久久久久久久久| 欧美一区二区精品久久911| 欧美高清你懂得| 亚洲一区免费网站| 欧美成人精品一区| 国内一区二区三区| 亚洲欧洲99久久| 亚洲东热激情| 久久久久久久一区二区三区| 欧美体内she精视频| 亚洲欧洲在线免费| 久久久天天操| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 亚洲视频一区在线| 美女主播精品视频一二三四| 亚洲欧美国产毛片在线|