#include #include #include #include #include #include #include #include #include #include #include #include #include #define JUDGE using namespace std; int N, M, T; map MAP; vector people; vector names; vector > ques; vector states; int main() { #ifndef JUDGE freopen("input.txt", "r", stdin); #endif int i; string name, surname; cin >> N >> M; states.resize(N + 1); ques.resize(N + 1); people.resize(M + 1); names.resize(M + 1); for (i = 0; i < M; ++i) { cin >> name >> surname; people[i + 1] = 0; names[i + 1] = name + " " + surname; MAP.insert(make_pair(name, i + 1)); MAP.insert(make_pair(surname, i + 1)); } cin >> T; int t, x, j = 0; for (i = 1; i <= T; ++i) { cin >> t; if (t == 1) { cin >> x; if (states[x] == 0) { states[x] = 1; ques[x].clear(); } else { states[x] = 0; for (j = ques[x].size() - 1; j >= 0; --j) { people[ques[x][j]] = 0; } ques[x].clear(); } } if (t == 2) { cin >> x; cin >> name; int pos = MAP[name]; people[pos] = x; ques[x].push_back(pos); } if (t == 3) { cin >> x; int poz = ques[x].front(); people[poz] = 0; ques[x].pop_front(); } if (t == 4) { cin >> x; if (ques[x].empty() || states[x] == 0) { cout << -1; } else { for (j = ques[x].size() - 1; j > 0; --j) { int poz = ques[x][j]; cout << names[poz] << ' '; } int poz = ques[x][0]; cout << names[poz]; } cout << '\n'; } if (t == 5) { cin >> name; int pos = MAP[name]; if (people[pos] == 0) cout << -1; else cout << people[pos]; cout << '\n'; } } #ifndef JUDGE while (1); #endif return 0; }