Pagini recente » Cod sursa (job #620762) | Cod sursa (job #1192174) | Cod sursa (job #50963) | Cod sursa (job #2969612) | Cod sursa (job #1222877)
#include <fstream>
#include <algorithm>
#include <vector>
#include <utility>
#include <queue>
#include <bitset>
#define NMAX 250005
#define VALMAX 1005
using namespace std;
int n,s,t;
vector<pair<int,int> > graf[NMAX];
int dist[NMAX];
bitset<NMAX> viz;
queue<int> coada[VALMAX];
inline void dijkstra(){
for(int i=1;i<=n;i++)
dist[i]=VALMAX;
dist[s]=0;
coada[0].push(s);
int y;
vector<pair<int,int> >::iterator it;
for(int i=0;i<VALMAX;i++){
while(!coada[i].empty()){
y=coada[i].front();
coada[i].pop();
if(!viz[y]){
viz[y]=1;
for(it=graf[y].begin();it!=graf[y].end();it++)
if(max(dist[y],it->second)<dist[it->first]){
dist[it->first]=max(dist[y],it->second);
coada[dist[it->first]].push(it->first);
}
}
}
}
}
int main()
{
ifstream cin("pscnv.in");
ofstream cout("pscnv.out");
ios_base::sync_with_stdio(false);
int m=0,a,b,c;
cin>>n>>m>>s>>t;
for(int i=1;i<=m;i++){
cin>>a>>b>>c;
graf[a].push_back(make_pair(b,c));
}
dijkstra();
cout<<dist[t]<<'\n';
cin.close();
cout.close();
return 0;
}