Pagini recente » Cod sursa (job #2145193) | Cod sursa (job #978123) | Cod sursa (job #1368018) | Cod sursa (job #436903) | Cod sursa (job #2664373)
//ALEXANDRU MICLEA
#include <vector>
#include <algorithm>
#include <string>
#include <queue>
#include <map>
#include <set>
#include <unordered_map>
#include <time.h>
#include <iomanip>
#include <deque>
#include <math.h>
#include <cmath>
#include <assert.h>
#include <stack>
#include <bitset>
#include <random>
#include <chrono>
#include <assert.h>
using namespace std;
#include <fstream>
//ifstream cin("input.in"); ofstream cout("output.out");
ifstream cin("stramosi.in"); ofstream cout("stramosi.out");
//VARIABLES
const int MAXN = 250005;
int st[MAXN][25];
int LOG[250005];
//FUNCTIONS
//MAIN
int main() {
int n, m;
cin >> n >> m;
for (int i = 1; i <= n; i++) cin >> st[i][0];
for (int p = 1; p <= log(n); p++) {
for (int i = 1; i <= n; i++) {
st[i][p] = st[st[i][p - 1]][p - 1];
}
}
for (int i = 1; i <= m; i++) {
int nod, rang;
cin >> nod >> rang;
while (rang) {
nod = st[nod][(int)log(rang)];
rang -= (1 << (int)log(rang));
}
cout << nod << '\n';
}
return 0;
}