Cod sursa(job #1878779)

Utilizator danysilas23Silas Daniel danysilas23 Data 14 februarie 2017 14:21:05
Problema Sate Scor 100
Compilator cpp Status done
Runda becreative15 Marime 0.72 kb
#include <fstream>
#include <vector>
#define f first
#define s second
#define mp make_pair
using namespace std;
ifstream fin("sate.in");
ofstream fout("sate.out");
int viz[30010];
vector<pair <int, int> > A[30010];
int n,m,a,b,x,y,start,cost;
void DFS(int nod){
    for(int i=0; i<A[nod].size(); i++){
        int nod2=A[nod][i].f;
       int cost=A[nod][i].s;
        if(!viz[nod2]){
         viz[nod2]=viz[nod]+cost;
        DFS(nod2);
        }
    }
}
int main()
{
    fin>>n>>m>>x>>y;
    if(x>y) swap(x,y);
     for(int i=1; i<=m; i++){
        fin>>a>>b>>cost;
        A[a].push_back(mp(b,cost));
        A[b].push_back(mp(a,-cost));
    }
    DFS(x);
    fout<<viz[y]<<'\n';
    return 0;
}