返回题解分享
讨论 / 题解分享/ 帖子详情

海贼王之伟大航路 - 题解



#include<bits/stdc++.h>
using namespace std;
// typedef long long ll;
const int N=21;
int n;
int d[N][N];
bool st[N];
int ans=0x3f3f3f3f;
void dfs(int u,int cnt,int cost)
{
if(cost>ans) return;
if(cnt==n&&u==n)
{
ans=min(ans,cost);
return;
}
for(int i=1;i<=n;i++)
{
if(i==u) continue;
if(st[i]) continue;
if(d[u][i]>ans) continue;
st[i]=true;
dfs(i,cnt+1,cost+d[u][i]);
st[i]=false;;
}
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
cin>>d[i][j];
}
}
st[1]=true;
dfs(1,1,0);
cout<<ans;
return 0;
}

0 回复 0 转发 0 喜欢 8 阅读
回复 (0)
默认 最新
暂无回复,快来抢沙发!