Cod sursa(job #2043782)

Utilizator stefdascalescuStefan Dascalescu stefdascalescu Data 20 octombrie 2017 16:05:15
Problema Sate Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.9 kb
#include<bits/stdc++.h>
using namespace std;
ifstream f("sate.in");
ofstream g("sate.out");
int n,m,x,y;
int dmin=1e8;
vector<int>v[30002];
vector<int>d[30002];
bool z[30002];
bool z1[30002];
void dfs(int nod, bool z[], int dsf)
{
    memcpy(z1,z,n+1);
    if(nod==y)
    {
        dmin=min(dmin,dsf);
        return;
    }
    for(int i=0;i<v[nod].size();++i){
        if(z1[v[nod][i]]==0){
            z1[v[nod][i]]=1;
            if(v[nod][i]>nod)
                dfs(v[nod][i],z1,dsf+d[nod][i]);
            else
                dfs(v[nod][i],z1,dsf-d[nod][i]);
            z1[v[nod][i]]=0;
        }
    }
}
int main()
{
    f>>n>>m>>x>>y;
    for(int i=1;i<=m;++i)
    {
        int a,b,c;
        f>>a>>b>>c;
        v[a].push_back(b);
        d[a].push_back(c);
        v[b].push_back(a);
        d[b].push_back(c);
    }
    dfs(x,z,0);
    g<<dmin;
    return 0;
}