Cod sursa(job #2233057)

Utilizator Andrei-27Arhire Andrei Andrei-27 Data 22 august 2018 01:07:55
Problema Sate Scor 30
Compilator cpp Status done
Runda Arhiva de probleme Marime 1 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <deque>
using namespace std;
const int NR=30005;
vector < int > v[NR];
vector < int > w[NR];
deque  < int > q;
ifstream f("sate.in");
ofstream g("sate.out");
int n,m,x,y;
long long drum[NR];
void citire (){
    f>>n>>m>>x>>y;
    for(int i=0;i<n;i++){
        int a,b,c;
        f>>a>>b>>c;
        v[a].push_back(b);
        v[b].push_back(a);
        w[a].push_back(c);
        w[b].push_back(c);}}
void BFS (int x){
    for(int i=1;i<=n;i++) drum[i]=-1;
    drum[x]=0;
    q.push_back(x);
    while (!q.empty()){
        int node=q.front();
        q.pop_front();
        for(int i=0;i<v[node].size();i++)
            if(drum[v[node][i]]==-1)
            {q.push_back(v[node][i]);
            if(v[node][i]>node) drum[v[node][i]]=drum[node]+w[node][i];
            else                drum[v[node][i]]=drum[node]-w[node][i];
            if(v[node][i]==y) {g<<drum[y]; return;}}}}
int main ()
{   citire();
    BFS(x);}