Pagini recente » Cod sursa (job #479821) | Cod sursa (job #1352109) | Cod sursa (job #617805) | Cod sursa (job #2398774) | Cod sursa (job #2152071)
#include <fstream>
#include <vector>
#define N 30005
using namespace std;
ifstream fin ("sate.in");
ofstream fout("sate.out");
int dist[N];
vector <pair <int, int> > G[N];
bool viz[N];
void DFS(const int &nod)
{
viz[nod] = 1;
for(auto i : G[nod])
if(!viz[i.first] && dist[i.first] == 0)
{
dist[i.first] = dist[nod] + i.second;
DFS(i.first);
}
viz[nod] = 0;
}
int main()
{
int n, m, X, Y;
fin >> n >> m >> X >> Y;
for(int i = 1, x, y, c; i <= m; ++i)
{
fin >> x >> y >> c;
G[min(x,y)].push_back(make_pair(max(x,y), c));
G[max(x,y)].push_back(make_pair(min(x,y), -c));
}
fin.close();
DFS(X);
fout << dist[Y];
fout.close();
return 0;
}