Cod sursa(job #2233054)

Utilizator Andrei-27Arhire Andrei Andrei-27 Data 22 august 2018 00:47:57
Problema Sate Scor 30
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.97 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <queue>
using namespace std;
const int NR=30005;
vector < int > v[NR];
vector < int > w[NR];
queue  < int > q;
ifstream f("sate.in");
ofstream g("sate.out");
int n,m,x,y,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(x);
    while (!q.empty()){
        int node=q.front();
        q.pop();
        for(int i=0;i<v[node].size();i++)
            if(drum[v[node][i]]==-1)
            {q.push(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);}