Pagini recente » Cod sursa (job #3338959) | Cod sursa (job #3343794) | Cod sursa (job #2945045) | Cod sursa (job #3319050) | Cod sursa (job #3337546)
#include <bits/stdc++.h>
using namespace std;
ifstream f("hamilton.in");
ofstream g("hamilton.out");
int n,m,dp[1<<18][19];
int main()
{
f>>n>>m;
vector<vector<pair<int,int>>> adj(n+1);
for(int i=1;i<=m;i++)
{
int a,b,c;
f>>a>>b>>c;
adj[a].push_back(make_pair(b,c));
}
for(int mask=1;mask<1<<n;mask++)
for(int i=0;i<n;i++)
dp[mask][i]=1e9;
dp[1][0]=0;
for(int mask=1;mask<1<<n;mask++)
for(int nod1=0;nod1<n;nod1++)
if(mask & (1<<nod1))
for(pair<int,int> x:adj[nod1])
{
int nod2=x.first;
int cost=x.second;
if(!(mask & (1<<nod2)))
{
int newmask=mask | (1<<nod2);
dp[newmask][nod2]=min(dp[mask][nod1]+cost,dp[newmask][nod2]);
}
}
int sol=1e9;
for(int i=1;i<n;i++)
for(auto x:adj[i])
if(x.first==0)
sol=min(sol,dp[(1<<n)-1][i]+x.second);
if(sol!=1e9)
g<<sol;
else g<<"Nu exista solutie";
return 0;
}