一、要求
1、统计给定时间点的,停车场内车数;
2、找到最长停车时间的车辆。
二、思路
1、对所有输入记录排序, 相同车牌号的记录放在一起,且时间升序。
2、遍历记录,若相邻两记录车牌号相同,且前一是in,后一为out,则为一个有效记录。将有效记录转存至数组L,并查询该车辆停车时间是否最长。
2、对数组L按进入停车场时间排序,统计每个时间点停车场人数,复杂度O(max(有效车牌数, K))。
三、代码
#include <cstdio>
#include <iostream>
#include <string>
#include <vector>
#include <map>
#include <algorithm>
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);
}