Pagini recente » Cod sursa (job #1880671) | Rating Bolborea Gabriel (xgb2004) | Cod sursa (job #841240) | Cod sursa (job #2965730) | Cod sursa (job #2870942)
#include <iostream>
#include <fstream>
#include <vector>
using namespace std;
const string filename = "hamilton";
ifstream fin(filename + ".in");
ofstream fout(filename + ".out");
const int inf = 0x3f3f3f3f;
int n, m, cost[20][20], dp[262150][20];
vector <int> G[20];
int main()
{
fin >> n >> m;
for(int i = 1; i <= m; i++)
{
int x, y, c;
fin >> x >> y >> c;
cost[x][y] = c;
G[y].push_back(x);
}
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 config = 1; config < (1 << n); config++)
for(int nod = 0; nod < n; nod++)
if(config && (1 << nod))
for(int vecin : G[nod])
if(config && (1 << vecin))
dp[config][nod] = min(dp[config][nod], dp[config ^ (1 << nod)][vecin] + cost[vecin][nod]);
int ans = inf;
for(int vecin : G[0])
ans = min(ans, dp[(1 << n) - 1][vecin] + cost[vecin][0]);
if(ans == inf)
fout << "Nu exista solutie";
else
fout << ans;
return 0;
}