Pagini recente » Cod sursa (job #1601435) | Cod sursa (job #1909734) | Cod sursa (job #1296860) | Cod sursa (job #1428175) | Cod sursa (job #2057866)
#include <stdio.h>
#include<fstream>
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#define NN 30010
#include <queue>
using namespace std;
ifstream in("sate.in");ofstream out("sate.out");
int n , m , ni, nf;
struct nod{
int dist, info;
nod *next;
}*L[NN];
void adaug(int x , int y,int cost)
{
//adaug pe y la lista lui x
nod * aux = new nod;
aux -> info = y;
aux->dist=cost;
aux-> next = L[x];
L[x]=aux;
}
void citire()
{
in >> n >> m>> ni >>nf;
for(int i = 0 ; i< m ; ++i )
{
int x, y,c;
in >> x>> y>>c;
adaug(x,y,c);
adaug(y,x,c);
}
}
bool viz[NN];
int bfs(int NOD, int D)
{viz[NOD]=true;
if(NOD==nf)return D;
else {
for( nod * aux = L[NOD]; aux ; aux = aux -> next)
if(!viz[aux->info])
{
if(NOD- aux->info >0)
{
return bfs(aux->info,D-aux->dist);
}
else {
return bfs(aux->info,D+aux->dist);
}
}
}
}
int main()
{ citire();
out <<bfs(ni,0);
return 0;
}