题目链接
建立一个队列存储队伍team中所有小组的编号,再为每个小组i建立一个队列mem[i]存储这个小组中的所有成员。当一个编号为x,组号为y的人来到队伍时,我们直接把x插入mem[y]末尾。如果插入之前mem[y]是空的,就把y插入到team末尾。出队时把mem[y]队头出队,如果mem[y]为空,就在team里面出队。
#include<cstdio>
#include<queue>
#include<cstring>
#include<map>
using namespace std;
#define _rep(i,a,b) for(int i=(a);i<=(b);i++)
#define _for(i,a,b) for(int i=(a);i<(b);i++)
const int N=