Comisia is sitting on a bench at a train station in Bucharest, waiting to board a train to Cluj-Napoca. Inside the waiting room, there are N
ticket counters. Being bored, she decides to study the ticket counters.
A counter is either open (the ticket-seller is selling tickets) or closed (the ticket-seller is on a lunch break). While Comisia is waiting, the ticket-sellers take breaks and return multiple times. A queue is formed in front of each ticket counter, working by the first come, first served principle. When a counter closes, all the people waiting at that counter leave.
Our friend, Comisia, also notices that inside the waiting room, there are M
other passengers, some of who are waiting to buy a ticket from one of the counters. Each passenger has a name and surname, strings which consist of lower case and upper case letters. It is known that all names are distinct, all surnames are distinct and all the names are different from all the surnames.
Because Comisia doesn't want you to be as bored as she is, she asks you to help her perform T
operations, considering that at the beginning all the ticket counters are closed and there are no people waiting in line. The operations are:
- 1 x
- Counter x changes its state (open/closed). If x closes then all the people waiting there leave.
- 2 x myName
- A person with the name or surname
myName
queues at ticket counterx
. - 3 x
- The first person waiting in line at counter x is served and then leaves the queue.
- 4 x
- Comisia wants you to output on a line the full names (name + surname) of all the people waiting in line at counter
x
, from last to first. If there are no people waiting at counterx
, output-1
. - 5 myName
- Output the index of the queue where person
myName
is waiting. If the person is not part of a queue, output-1
.Input
On the first line you are givenN
andM
. The followingM
lines contain thename
andsurname
of each passenger, separated by a blank space. The line after the names containsT
, the number of operations, followed byT
lines, each containing an operation in one of the given formats.Output
Print a line for each operation of type 4 or 5, as described above.Constraints
1 ≤ N,M,T ≤ 100
- The names and surnames have a maximum length of 20 letters.
- Upper case letters are considered different from lower case letters.
- It is guaranteed that all the given operations are possible.
- The ticket counters are 1-based indexed, and so do the queues (eg. The first queue is number 1, the second queue is number 2 etc.).
Sample
Input Output 5 3
Simion Tulea
Leonida Pascalopol
Costache Giurgiuveanu
8
1 1
2 1 Simion
2 1 Pascalopol
2 1 Giurgiuveanu
4 1
3 1
4 1
5 CostacheCostache Giurgiuveanu Leonida Pascalopol Simion Tulea
Costache Giurgiuveanu Leonida Pascalopol
1
1 #include <iostream> 2 #include <string> 3 #include <map> 4 #include <deque> 5 using namespace std; 6 map<string,string> coresp; 7 map<string,bool> e_nume; 8 deque<string> coada[105]; 9 map<string,int> unde; 10 11 int main() { 12 int n,m,t,i,tip,x; 13 cin>>n>>m; 14 string nume,prenume; 15 for(i=0;i<m;i++) { 16 cin>>nume>>prenume; 17 coresp[nume]=prenume,coresp[prenume]=nume; 18 e_nume[nume]=1; 19 unde[nume]=-1; 20 } 21 cin>>t; 22 for(i=0;i<t;i++){ 23 cin>>tip; 24 if(tip==1) { 25 cin>>x; 26 deque<string>::iterator it; 27 for(it=coada[x].begin();it!=coada[x].end();it++) 28 unde[*it]=-1; 29 coada[x].clear(); 30 } else if(tip==2){ 31 cin>>x>>nume; 32 if(!e_nume[nume]) 33 nume=coresp[nume]; 34 unde[nume]=x; 35 coada[x].push_back(nume); 36 } else if(tip==3){ 37 cin>>x; 38 unde[coada[x].front()]=-1; 39 coada[x].pop_front(); 40 } else if(tip==5){ 41 cin>>nume; 42 if(!e_nume[nume]) 43 nume=coresp[nume]; 44 cout<<unde[nume]<<'\n'; 45 } else{ 46 cin>>x; 47 if(coada[x].empty()){ 48 cout<<"-1\n"; 49 continue; 50 } 51 deque<string>::reverse_iterator it; 52 it=coada[x].rbegin(); 53 cout<<*it<<' '<<coresp[*it]; 54 for(it++;it!=coada[x].rend();it++) 55 cout<<' '<<*it<<' '<<coresp[*it]; 56 cout<<'\n';} 57 } 58 return 0; 59 } 60(Sursa de Andrei Constantinescu)