#include using namespace std; int main(){ using ll=long long; ll inf=2e18; ll n,m,k,s,t; cin>>n>>m>>k>>s>>t; s--;t--; vector> g(n); for (int i=0;i>u>>v; u--;v--; g[u].push_back(v); g[v].push_back(u); } auto f=[&](int s){ vector> dist(n,vector(2,inf)); queue> q; dist[s][0]=0; q.push({s,0}); while (!q.empty()){ auto [v,i]=q.front(); q.pop(); for (int u:g[v]){ if (dist[u][i^1]!=inf) continue; dist[u][i^1]=dist[v][i]+1; q.push({u,i^1}); } } return dist; }; auto ds=f(s),dt=f(t); bool ok=false; auto check=[&](ll d){ int i=d%2; if (d