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

糯米

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

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

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

首先考慮一個子問題:指定一些點,添加一些邊,讓它們連通,并且總邊權(quán)最小。
這個問題就是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}},

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


#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 糯米 閱讀(1118) 評論(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>
            亚洲精品一区二区三区99| 毛片一区二区三区| 亚洲精品欧美在线| 欧美伊人久久大香线蕉综合69| 亚洲欧洲日本在线| 久久精品1区| 久久大香伊蕉在人线观看热2| 欧美成黄导航| 欧美成人激情视频免费观看| 国产免费观看久久黄| 亚洲精品中文字幕女同| 亚洲黄一区二区三区| 久久久精品国产免费观看同学| 午夜精品久久久99热福利| 欧美日韩国产不卡| 亚洲人成艺术| 亚洲三级视频| 女人香蕉久久**毛片精品| 狼人天天伊人久久| 国产一区二区三区av电影| 亚洲一区二区欧美日韩| 午夜精品久久久久久久99樱桃 | 亚洲日本一区二区三区| 久久国产精品网站| 久久久精品国产99久久精品芒果| 国产精品美女主播| 亚洲影院免费| 欧美在线看片| 国产一区二区三区四区三区四| 亚洲综合精品| 欧美专区在线观看一区| 国产色爱av资源综合区| 欧美一区二区三区成人| 久久九九有精品国产23| 黄色国产精品一区二区三区| 久久精品国产视频| 六十路精品视频| 91久久久久久久久| 欧美日韩国产123| 亚洲深爱激情| 久久精品二区| 尤物九九久久国产精品的特点| 鲁大师成人一区二区三区 | 亚洲精品女人| 夜久久久久久| 国产精品多人| 久久黄色级2电影| 欧美激情视频一区二区三区在线播放 | 久久久夜精品| 亚洲国产毛片完整版 | 亚洲欧美日韩精品久久久久| 久久尤物电影视频在线观看| 亚洲人在线视频| 欧美日韩综合不卡| 久久成人资源| 亚洲老板91色精品久久| 午夜精品久久久久久久久| 国产有码在线一区二区视频| 蜜桃av一区二区在线观看| 亚洲精品欧美| 久久久噜噜噜久久人人看| 亚洲欧洲综合| 国产日本精品| 欧美福利视频| 欧美亚洲视频一区二区| 亚洲国产毛片完整版| 午夜精品久久久久久99热软件| 黄色成人免费观看| 欧美片第一页| 久久av最新网址| 夜夜爽www精品| 免费在线观看一区二区| 亚洲天堂视频在线观看| 亚洲第一区在线观看| 国产精品久久九九| 欧美va亚洲va香蕉在线| 欧美一区二区久久久| 99视频精品全部免费在线| 嫩模写真一区二区三区三州| 亚洲欧美成人一区二区在线电影 | 国产九九视频一区二区三区| 免费成人毛片| 久久九九国产精品怡红院| 一卡二卡3卡四卡高清精品视频| 美女精品在线观看| 欧美在线啊v一区| 亚洲午夜极品| 亚洲免费观看高清在线观看| 一区二区三区在线不卡| 国产模特精品视频久久久久| 欧美日韩影院| 欧美日韩国产a| 狂野欧美一区| 久久久视频精品| 久久www免费人成看片高清| 亚洲一区免费网站| 亚洲尤物精选| 亚洲一区二区3| 亚洲深夜激情| 亚洲专区在线视频| 亚洲一区二区视频在线| 9色精品在线| 日韩亚洲不卡在线| 亚洲精品在线视频观看| 亚洲精品国产精品国自产观看浪潮| 麻豆久久精品| 牛牛影视久久网| 欧美va天堂在线| 欧美成人精品一区二区| 欧美成人午夜激情| 亚洲大片精品永久免费| 亚洲第一网站| 亚洲国产日韩精品| 亚洲另类在线一区| 日韩图片一区| 亚洲网站视频| 欧美在线视频在线播放完整版免费观看 | 免费在线观看一区二区| 欧美成人精品在线| 亚洲欧洲另类国产综合| 99在线热播精品免费| 一区二区三区欧美在线| 亚洲综合激情| 久久久91精品国产一区二区三区 | 久久精品欧美日韩精品| 久久久久久久尹人综合网亚洲| 久色婷婷小香蕉久久| 欧美精品久久久久a| 欧美偷拍另类| 国产午夜精品在线观看| 1024亚洲| 9国产精品视频| 香蕉乱码成人久久天堂爱免费| 久久精品国产v日韩v亚洲| 欧美va天堂| 日韩西西人体444www| 香蕉av福利精品导航| 老司机一区二区三区| 欧美日本在线视频| 国产日韩一区在线| 亚洲高清视频在线| 亚洲永久免费| 玖玖玖国产精品| 亚洲美女诱惑| 欧美一区二区三区四区在线 | 久久中文久久字幕| 欧美深夜影院| 国产一区欧美| 一区二区三区免费网站| 久久精品青青大伊人av| 亚洲韩国精品一区| 午夜精品久久久久久久男人的天堂| 鲁大师影院一区二区三区| 国产精品黄色| 激情综合自拍| 欧美一区二区三区婷婷月色| 亚洲第一色在线| 久久国产66| 国产精品久久久久毛片软件| 亚洲精品1区| 久久综合九色综合欧美狠狠| 99国产精品| 欧美jizz19性欧美| 韩日精品在线| 亚洲自拍偷拍视频| 亚洲欧洲一级| 久久亚洲综合网| 国产日韩欧美在线一区| 亚洲午夜精品| 亚洲国产一区视频| 另类春色校园亚洲| 国际精品欧美精品| 亚洲深夜影院| 91久久国产综合久久| 久久精品二区| 国产欧美激情| 亚洲欧美www| 日韩视频免费观看高清完整版| 媚黑女一区二区| 一区二区三区在线免费视频| 香蕉久久一区二区不卡无毒影院| 亚洲理论在线| 欧美连裤袜在线视频| 亚洲东热激情| 欧美肥婆在线| 美女诱惑一区| 亚洲国产婷婷综合在线精品| 久久综合国产精品| 久久精品视频在线| 国内精品免费在线观看| 性视频1819p久久| 午夜一区二区三视频在线观看 | 欧美日韩中文字幕| 99国内精品久久| 亚洲精品视频在线| 欧美日韩大陆在线| 亚洲一区在线观看视频 | 亚洲天堂免费在线观看视频| 亚洲美女福利视频网站| 欧美网站在线观看|