Pagini recente » Cod sursa (job #1575351) | Cod sursa (job #2224036) | Cod sursa (job #1339619) | Cod sursa (job #2911110) | Cod sursa (job #2243883)
#include <fstream>
#include <vector>
const int MAX_N = 30000;
using namespace std;
ifstream fin("sate.in");
ofstream fout("sate.out");
struct Muchie {
int v, c;
};
Muchie x, y;
long long n, m, s, ok;
int vizitat[MAX_N + 1];
vector<Muchie> vecini[MAX_N + 1];
void dfs(Muchie u) {
vizitat[u.v] = 1;
if (ok == 1)
return;
if(u.v == y.v) {
return;
ok = 1;
}
for(auto v : vecini[u.v])
if(!vizitat[v.v]) {
s+=v.c;
dfs(v);
}
}
int main()
{
fin >> n >> m >> x.v >> y.v;
for (int i = 1; i <= n; i++) {
int u, w, c;
fin >> u >> w >> c;
vecini[u].push_back({w, c});
vecini[w].push_back({u, -c});
}
dfs(x);
fout << s << '\n';
return 0;
}