共有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; }