poj3311 Hie with the Pie

poj3311 Hie with the Pieios

題目描述

共有n+1個點,問從點1出發走完全部點後回到1點所須要的最少時間spa

輸入輸出格式

輸入格式:

第一行行一個數,ncode

接下來n+1行,每行n+1個數,表示從i到j的時間。get

輸出格式:

一個整數,表示最少時間。string

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int n,a[15][15],f[15][11000];
int read()
{
    int n=0,f=1;char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
    while(c>='0'&&c<='9'){n=n*10+c-'0';c=getchar();}
    return n*f;
}
int main()
{
    while(1)
    {
        n=read();
        if(n==0)break;
        n++;
        for(int i=1;i<=n;++i)
            for(int j=1;j<=n;++j)
                a[i][j]=read();
        for(int k=1;k<=n;++k)
            for(int i=1;i<=n;++i)
                for(int j=1;j<=n;++j)
                    a[i][j]=min(a[i][j],a[i][k]+a[k][j]);
        memset(f,0x3f,sizeof(f));
        f[1][1]=0;
        for(int i=1;i<(1<<n);++i)
            for(int j=1;j<=n;++j)
                if((i&(1<<(j-1)))!=0)
                    for(int k=1;k<=n;++k)
                        if((i&(1<<(k-1)))==0)f[k][i|(1<<(k-1))]=min(f[k][i|(1<<(k-1))],f[j][i]+a[j][k]);
        int ans=0x3f3f3f3f;
        for(int i=2;i<=n;++i)
            ans=min(ans,f[i][(1<<n)-1]+a[i][1]);
        printf("%d\n",ans);
    }
    return 0;
}
相關文章
相關標籤/搜索