PAT A 1095 Cars on Campus (30 分)

一、要求

1、统计给定时间点的,停车场内车数;
2、找到最长停车时间的车辆。

二、思路

1、对所有输入记录排序, 相同车牌号的记录放在一起,且时间升序。
2、遍历记录,若相邻两记录车牌号相同,且前一是in,后一为out,则为一个有效记录。将有效记录转存至数组L,并查询该车辆停车时间是否最长。
2、对数组L按进入停车场时间排序,统计每个时间点停车场人数,复杂度O(max(有效车牌数, K))。

三、代码

#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;
struct node
{
	string id;
	int time, tag;
};
int cmp1(node a, node b)
{
	if( a.id != b.id )
		return a.id < b.id;
	return a.time < b.time;
}
int cmp2(node a, node b)
{
	return a.time < b.time;
}
int main()
{
	int N, K, Max = 0;
	scanf("%d %d", &N, &K);
	map<string, int> park_time;
	vector<node> rec(N), L;
	vector<string> ans;
	for( int i = 0, h, m, s; i < N; ++i )
	{
		string status;
		cin >> rec[i].id;
		scanf("%d:%d:%d", &h, &m, &s);
		cin >> status;
		rec[i].time = h * 3600 + m * 60 + s;
		rec[i].tag = (status == "out");
	}
	sort(rec.begin(), rec.end(), cmp1);
	for( int i = 1, time; i < N; ++i )
		if( rec[i].tag > rec[i - 1].tag && rec[i].id == rec[i - 1].id )
		{
			L.push_back(rec[i - 1]);
			L.push_back(rec[i]);
			park_time[rec[i].id] += rec[i].time - rec[i - 1].time;
			time = park_time[rec[i].id];
			if( time > Max )
			{
				Max = time;
				ans.clear();
				ans.push_back(rec[i].id);
			}
			else if( time == Max )
				ans.push_back(rec[i].id);
		}
	sort(L.begin(), L.end(), cmp2);
	for( int i = 0, j = 0, h, m, s, time, cnt = 0; i < K; ++i )
	{
		scanf("%d:%d:%d", &h, &m, &s);
		time = h * 60 * 60 + m * 60 + s;
		for( ; j < L.size() && L[j].time <= time; ++j )
			if( L[j].tag )
				--cnt;
			else ++cnt;
		printf("%d\n", cnt);

	}
	for(int i = 0; i < ans.size(); ++i )
		printf("%s ", ans[i].c_str());
	printf("%02d:%02d:%02d", Max / 3600, Max / 60 % 60, Max % 60);
}

你可能感兴趣的:(PAT,A)