#include #define syosu(x) fixed< P; typedef pair pdd; typedef pair pll; typedef vector vi; typedef vector vvi; typedef vector vd; typedef vector vvd; typedef vector vl; typedef vector vvl; typedef vector vs; typedef vector

vp; typedef vector vvp; typedef vector vpll; typedef pair pip; typedef vector vip; const ll INF=1ll<<60; const double pi=acos(-1); const double eps=1e-8; const ll mod=1e9+7; const int dx[4]={-1,0,1,0},dy[4]={0,-1,0,1}; class Graph{ private: int n; vvp g; public: ll DIJ(int s,int t){ priority_queue q; vl d(n,INF); d[s]=0; q.push({0,s}); while(!q.empty()){ pll p=q.top(); q.pop(); ll v=p.second; if(d[v]<-p.first) continue; for(auto i:g[v]){ ll u=i.first,D=d[v]+i.second; if(d[u]>D){ d[u]=D; q.push({-D,u}); } } } return d[t]; } Graph(int v){ n=v; g=vvp(v); } void add_edge(int s,int t,int c){ g[s].push_back({t,c}); } }; int n,m,h,u,v; vvi a; vi x,y,z,s; int f(int A,int B){ return lower_bound(a[A].begin(),a[A].end(),B)-a[A].begin()+s[A]; } int main(){ cin>>n>>m>>h>>u>>v; a=vvi(n); s=vi(n); a[0].push_back(u); a[n-1].push_back(v); x=y=z=vi(m); Graph g(2*m+2); for(int i=0;i>A>>B>>C; a[A-1].push_back(B); a[A].push_back(C); x[i]=A,y[i]=B,z[i]=C; } for(int i=0;i