2020-09-24 18:35:01 +08:00
|
|
|
// R38818598
|
|
|
|
|
|
|
|
#include <bits/stdc++.h>
|
|
|
|
|
|
|
|
using namespace std;
|
|
|
|
|
|
|
|
struct node {
|
|
|
|
string name;
|
2021-11-19 17:01:13 +08:00
|
|
|
bool towards;
|
2020-09-24 18:35:01 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
// freopen("data/P1563_sample1.in", "r", stdin);
|
2021-11-19 17:01:13 +08:00
|
|
|
int n, m, now = 0, x, y;
|
2020-09-24 18:35:01 +08:00
|
|
|
node a[100005];
|
|
|
|
cin >> n >> m;
|
|
|
|
for (int i = 0; i < n; i++) {
|
|
|
|
cin >> a[i].towards >> a[i].name;
|
|
|
|
}
|
|
|
|
for (int i = 0; i < m; i++) {
|
|
|
|
cin >> x >> y;
|
|
|
|
if (a[now].towards == 0) {
|
|
|
|
if (x == 0) {
|
|
|
|
now = (now + n - y) % n;
|
2021-11-19 17:01:13 +08:00
|
|
|
} else if (x == 1) {
|
2020-09-24 18:35:01 +08:00
|
|
|
now = (now + y) % n;
|
|
|
|
}
|
2021-11-19 17:01:13 +08:00
|
|
|
} else if (a[now].towards == 1) {
|
2020-09-24 18:35:01 +08:00
|
|
|
if (x == 0) {
|
|
|
|
now = (now + y) % n;
|
2021-11-19 17:01:13 +08:00
|
|
|
} else if (x == 1) {
|
2020-09-24 18:35:01 +08:00
|
|
|
now = (now + n - y) % n;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cout << a[now].name << endl;
|
|
|
|
return 0;
|
|
|
|
}
|