Pagini recente » Cod sursa (job #876606) | Cod sursa (job #2538491) | Cod sursa (job #769365) | Cod sursa (job #588887) | Cod sursa (job #2443465)
#include <fstream>
#include <iostream>
#include <vector>
#define NMAX 250000
#define MMAX 300000
using namespace std;
ifstream f("stramosi.in");
ofstream g("stramosi.out");
int n, m, top, stiva[NMAX+10], ans[MMAX+10];
bool b[NMAX+10];
vector <int> nod[NMAX+10];
vector <pair <int, int> > query[NMAX+10];
void DFS(int x)
{
b[x] = 1;
stiva[++top] = x;
for(int i=0; i<query[x].size(); i++)
{ if(top <= query[x][i].first) ans[query[x][i].second] = 0;
else ans[query[x][i].second] = stiva[top-query[x][i].first];
}
for(int i=0; i<nod[x].size(); i++)
if(!b[nod[x][i]])
DFS(nod[x][i]);
top--;
}
int main()
{
f >> n >> m;
for(int i=1; i<=n; i++)
{ int x;
f >> x;
if(x)
{ nod[i].push_back(x);
nod[x].push_back(i);
}
}
for(int i=1; i<=m; i++)
{ int x, y;
f >> x >> y;
query[x].push_back(make_pair(y, i));
}
for(int i=1; i<=n; i++) if(!b[i]) DFS(i);
for(int i=1; i<=m; i++) g << ans[i] << '\n';
return 0;
}