Pagini recente » Cod sursa (job #2756185) | Cod sursa (job #3173795) | Cod sursa (job #2138419) | Cod sursa (job #1669120) | Cod sursa (job #1878758)
#include <fstream>
#include <vector>
#define f first
#define s second
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 nod_nou=A[nod][i].f;
int cost=A[nod][i].s;
if(!viz[nod_nou]){
viz[nod_nou]=viz[nod]+cost;
DFS(nod_nou);
}
}
}
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({b,cost});
A[b].push_back({a,-cost});
}
DFS(x);
fout<<viz[y]<<'\n';
return 0;
}