Pagini recente » Cod sursa (job #1166245) | Cod sursa (job #1513198) | Cod sursa (job #740375) | Cod sursa (job #2202147) | Cod sursa (job #2135606)
#include <cstdio>
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
#define nmax 30005
struct str
{
int nod,cost;
};
vector<str>Q[nmax];
queue<int>que;
FILE *f=fopen("sate.in","r");
FILE *g=fopen("sate.out","w");
int n,m,x,y,dist[nmax];
void read()
{
fscanf(f,"%d %d %d %d",&n,&m,&x,&y);
for (int i=1; i<=m; ++i)
{
int r1,r2,r3;
fscanf(f,"%d %d %d",&r1,&r2,&r3);
if (r1>r2)
{
Q[r1].push_back({r2,-r3});
Q[r2].push_back({r1,r3});
}
else
{
Q[r1].push_back({r2,r3});
Q[r2].push_back({r1,-r3});
}
}
}
void dfs(int nod)
{
for (auto w:Q[nod])
{
int nextnod=w.nod;
if (!dist[nextnod])
{
dist[nextnod]=dist[nod]+w.cost;
dfs(nextnod);
}
}
}
void solve()
{
dist[x]=1;
dfs(x);
fprintf(g,"%d",dist[y]-1);
}
int main()
{
read();
solve();
return 0;
}