Pagini recente » Cod sursa (job #2742689) | Cod sursa (job #1115898) | Cod sursa (job #1583674) | Cod sursa (job #109819) | Cod sursa (job #3217464)
#include <bits/stdc++.h>
#define ll long long
#define INF 1000000000
using namespace std;
ifstream fin ("hamilton.in");
ofstream fout ("hamilton.out");
ll dp[272144][20];
ll mat[20][20];
vector <ll> gt[20];
int main()
{
int n, m, a, b, c;
fin>>n>>m;
for (int i=1; i<=m; i++) {
fin>>a>>b>>c;
gt[b].push_back(a);
mat[a][b]=c;
}
for (int i=0; i<(1<<n); i++) {
for (int j=0; j<n; j++) {
dp[i][j]=INF;
}
}
dp[1][0]=0;
for (int i=1; i<(1<<n); i++) {
for (int j=0; j<n; j++) {
if (i&(1<<j)) {
int iold=i-(1<<j);
for (int vecin: gt[j]) {
if (iold&(1<<vecin)) {
dp[i][j]=min(dp[i][j], dp[iold][vecin]+mat[vecin][j]);
}
}
}
}
}
ll mini=INF;
for (int vecin : gt[0]) {
if (dp[(1<<n)-1][vecin]+mat[vecin][0]<mini) {
mini=dp[(1<<n)-1][vecin]+mat[vecin][0];
}
}
if (mini!=INF) fout<<mini;
else fout<<"Nu exista solutie";
return 0;
}