思路:
因为用户按时间顺序输入,把用户存进队列,当队列非空时依次弹出,判断后面的用户是否和当前用户在同一个朋友圈里,如果是,判断处理完当前用户事务之前,朋友是否已经来到,如果来到,帮忙处理。
核心问题:
- 如何判断两个用户是否在一个集合?
使用Map。其中Key为用户名字,Value为朋友圈。 - 如何遍历当前用户后面的用户?
开一个数组保存,从当前用户下标开始遍历。
#include <iostream>
#include <map>
#include <queue>
#include <cstdio>
using namespace std;
#define MaxNameLen 3
#define MaxPeopleNum 10000
typedef struct People ElementType;
typedef int Position;
struct People {
int T;
int P;
char Name[MaxNameLen + 1];
Position Index;
} PQueue[MaxPeopleNum];
int main()
{
//freopen("E:in.txt", "r", stdin);
map<string, int> Group;
queue<ElementType> Que;
char Name[MaxNameLen + 1];
int N, M, L, i