Cod sursa(job #3337546)

Utilizator jarnea_justinjarnea justin ioan jarnea_justin Data 28 ianuarie 2026 18:45:32
Problema Ciclu hamiltonian de cost minim Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.03 kb
#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;
}