Cod sursa(job #2870942)

Utilizator toma_ariciuAriciu Toma toma_ariciu Data 12 martie 2022 18:46:20
Problema Ciclu hamiltonian de cost minim Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.13 kb
#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;
}