Pagini recente » Cod sursa (job #2565289) | Cod sursa (job #2024717) | Cod sursa (job #1877146) | Cod sursa (job #2777486) | Cod sursa (job #353372)
Cod sursa(job #353372)
#include<fstream.h>
ifstream fin("sate.in");
ofstream fout("sate.out");
int n,m,x,y,c[30001];
long d[30001];
int xx[100025],yy[100025],dist[100025];
void parcurgere()
{int p,u,aux,i;
c[1]=x;
d[x]=0;
p=u=1;
while(p<=u)
{aux=c[p];
p++;
for(i=1;i<=n;i++)
if(xx[i]==aux && d[yy[i]]==0)
{u++;
c[u]=yy[i];
if(yy[i]>=aux) d[yy[i]]=d[aux]+dist[i];
else d[yy[i]]=d[aux]-dist[i];
}
else
if(yy[i]==aux && d[xx[i]]==0)
{u++;
c[u]=xx[i];
if(xx[i]>=aux) d[xx[i]]=d[aux]+dist[i];
else d[xx[i]]=d[aux]-dist[i];
}
}
fout<<d[y];
}
int main()
{fin>>n>>m>>x>>y;
for(int i=1;i<=m;i++)
fin>>xx[i]>>yy[i]>>dist[i];
parcurgere();
fin.close();
fout.close();
return 0;
}