Cod sursa(job #2033591)

Utilizator GramaDavidGrama David Sebastian GramaDavid Data 7 octombrie 2017 00:49:49
Problema Sate Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.93 kb
#include <iostream>
#include <fstream>
#include <queue>
#include <vector>

using namespace std;

ifstream f("sate.in");
ofstream g("sate.out");

int dist[100001];
vector<pair <int,int> >vec[100001];
queue < int > q;

int main()
{
    int N,M,X,Y,i,j,D;
    f>>N>>M>>X>>Y;
    for(int h=1;h<=M;h++)
    {
        f>>i>>j>>D;
        vec[i].push_back({j,D});
        vec[j].push_back({i,D});
    }
    q.push(X);
    while(!q.empty())
    {
        X=q.front();
        q.pop();
        for(int h=0;h<vec[X].size();h++)
        {
            if(dist[vec[X][h].first]==0 && vec[X][h].first!=X)
            {
                q.push(vec[X][h].first);
                if(X<vec[X][h].first)
                    dist[vec[X][h].first]=vec[X][h].second+dist[X];
                else
                    dist[vec[X][h].first]=dist[X]-vec[X][h].second;
            }

        }
    }
    g<<dist[Y];
    return 0;
}