1095 Cars on Campus

Zhejiang University has 6 campuses and a lot of gates. From each gate we can collect the in/out times and the plate numbers of the cars crossing the gate. Now with all the information available, you are supposed to tell, at any specific time point, the number of cars parking on campus, and at the end of the day find the cars that have parked for the longest time period.

Input Specification:

Each input file contains one test case. Each case starts with two positive integers N (<= 10000), the number of records, and K (<= 80000) the number of queries. Then N lines follow, each gives a record in the format

plate_number hh:mm:ss status

where plate_number is a string of 7 English capital letters or 1-digit numbers; hh:mm:ss represents the time point in a day by hour:minute:second, with the earliest time being 00:00:00 and the latest 23:59:59; and status is either in or out.

Note that all times will be within a single day. Each “in” record is paired with the chronologically next record for the same car provided it is an “out” record. Any “in” records that are not paired with an “out” record are ignored, as are “out” records not paired with an “in” record. It is guaranteed that at least one car is well paired in the input, and no car is both “in” and “out” at the same moment. Times are recorded using a 24-hour clock.

Then K lines of queries follow, each gives a time point in the format hh:mm:ss. Note: the queries are given in ascending order of the times.

Output Specification:

For each query, output in a line the total number of cars parking on campus. The last line of output is supposed to give the plate number of the car that has parked for the longest time period, and the corresponding time length. If such a car is not unique, then output all of their plate numbers in a line in alphabetical order, separated by a space.

Sample Input:

16 7

JH007BD 18:00:01 in

ZD00001 11:30:08 out

DB8888A 13:00:00 out

ZA3Q625 23:59:50 out

ZA133CH 10:23:00 in

ZD00001 04:09:59 in

JH007BD 05:09:59 in

ZA3Q625 11:42:01 out

JH007BD 05:10:33 in

ZA3Q625 06:30:50 in

JH007BD 12:23:42 out

ZA3Q625 23:55:00 in

JH007BD 12:24:23 out

ZA133CH 17:11:22 out

JH007BD 18:07:01 out

DB8888A 06:30:50 in

05:10:00

06:30:50

11:00:00

12:23:42

14:00:00

18:00:00

23:59:00

Sample Output:

1

4

5

2

1

0

1

JH007BD ZD00001 07:20:09

题目大意:

让你模拟车库的停车过程。首先每辆车都有一个车牌号,和对应的时间和状态,如果状态是in表示入库,如果状态是Out表示出库。出库时间一定紧跟在入库时间之后,只有出库和入库像配对的才算做合法时间。给出K组查询,查询时间按照由小到大一次递增。每组查询要求你给出相应时间段内在停车库的车辆数。最终给出待在停车库内时间最长的车的车牌号以及相应时间。

大致思路

  1. 定义一个结构体用来存储各个车辆的信息。同时定义一个map用来建立车牌号和车辆信息之间的映射关系,方便后续对每辆车的进出时间进行排序。
  2. 对每一辆车的进出时间进行排序,同时按照题目要求判断合法的时间段,因为答案要求的是每辆车待在车库的最长时间,所以我们定义一个map<string, int> record用来记录每辆车待在车库里的时间,同时定义一个vector< pair<int, int> > during;用来记录每辆车的进入和离开时间。建立一个vector maxTime用来存储待在车库里最长时间的车牌号。
  3. 在查询时,把查询时间和during中的合法时间进行比较,如果查询时间大于进入时间表明有车进入如果查询时间小于进入时间表明有车离开。

代码

#include <bits/stdc++.h>

using namespace std;

const int N = 1e5 + 10;
struct node {
string id, status;
int hh, mm, ss; //时,分,秒
bool friend operator<(node a, node b) {
if (a.hh == b.hh) {
if (a.mm == b.mm) return a.ss < b.ss;
return a.mm < b.mm;
}
return a.hh < b.hh;
}
};
int n, k;
// typedef pair<int, int> P;
vector< pair<int, int> > during;
vector<string> maxTime; int main() {
scanf("%d%d", &n, &k);
map<string, vector<node>> car;
map<string, int> record; //记录每辆车的进入时间和最大时间
for (int i = 0; i < n; i++) {
node tmp;
cin >> tmp.id;
scanf("%d:%d:%d", &tmp.hh, &tmp.mm, &tmp.ss);
cin >> tmp.status;
car[tmp.id].push_back(tmp);
}
//对每一辆车出入时间进行排序
for (auto ite : car) {
auto tmp = ite.second;
sort(tmp.begin(), tmp.end());
int len = tmp.size();
for (int i = 0; i < len - 1; i++) {
if (tmp[i].status == "in" && tmp[i + 1].status == "out") {
int in_time = tmp[i].hh * 3600 + tmp[i].mm * 60 + tmp[i].ss;
int out_time =
tmp[i + 1].hh * 3600 + tmp[i + 1].mm * 60 + tmp[i + 1].ss;
int stay_time = out_time - in_time;
record[tmp[i].id] += stay_time; //记录每辆车待的最长时间
during.push_back(make_pair(
in_time, out_time)); // during记录每一辆车的进来和出去时间
}
}
if (maxTime.empty())
maxTime.push_back(ite.first);
else {
if (record[ite.first] == record[maxTime[0]])
maxTime.push_back(ite.first);
else if (record[ite.first] > record[maxTime[0]]) {
maxTime.clear();
maxTime.push_back(ite.first);
}
}
}
while (k--) {
int call_hh, call_mm, call_ss;
scanf("%d:%d:%d", &call_hh, &call_mm, &call_ss);
int last_time = call_hh * 3600 + call_mm * 60 + call_ss;
int ans = 0;
for (int i = 0; i < during.size(); i++) {
if (last_time >= during[i].first) ans++;
if (last_time >= during[i].second) ans--;
}
printf("%d\n", ans);
}
sort(maxTime.begin(), maxTime.end());
for (int i = 0; i < maxTime.size(); i++) cout << maxTime[i] << " ";
// cout << "最长时间为:" << record[maxTime[0]] << endl;
int ans_hh = record[maxTime[0]] / 3600;
record[maxTime[0]] %= 3600;
int ans_mm = record[maxTime[0]] / 60;
int ans_ss = record[maxTime[0]] % 60;
printf("%02d:%02d:%02d\n", ans_hh, ans_mm, ans_ss);
return 0;
}

运行结果如下图所示

1095 Cars on Campus——PAT甲级真题的更多相关文章

  1. PAT 甲级真题题解(63-120)

    2019/4/3 1063 Set Similarity n个序列分别先放进集合里去重.在询问的时候,遍历A集合中每个数,判断下该数在B集合中是否存在,统计存在个数(分子),分母就是两个集合大小减去分 ...

  2. PAT 甲级真题题解(1-62)

    准备每天刷两题PAT真题.(一句话题解) 1001 A+B Format  模拟输出,注意格式 #include <cstdio> #include <cstring> #in ...

  3. 1080 Graduate Admission——PAT甲级真题

    1080 Graduate Admission--PAT甲级练习题 It is said that in 2013, there were about 100 graduate schools rea ...

  4. PAT甲级真题及训练集

    正好这个"水水"的C4来了 先把甲级刷完吧.(开玩笑-2017.3.26) 这是一套"伪题解". wacao 刚才登出账号测试一下代码链接,原来是看不到..有空 ...

  5. PAT 甲级真题

    1019. General Palindromic Number 题意:求数N在b进制下其序列是否为回文串,并输出其在b进制下的表示. 思路:模拟N在2进制下的表示求法,“除b倒取余”,之后判断是否回 ...

  6. PAT甲级真题 A1025 PAT Ranking

    题目概述:Programming Ability Test (PAT) is organized by the College of Computer Science and Technology o ...

  7. Count PAT's (25) PAT甲级真题

    题目分析: 由于本题字符串长度有10^5所以直接暴力是不可取的,猜测最后的算法应该是先预处理一下再走一层循环就能得到答案,所以本题的关键就在于这个预处理的过程,由于本题字符串匹配的内容的固定的PAT, ...

  8. 1018 Public Bike Management (30分) PAT甲级真题 dijkstra + dfs

    前言: 本题是我在浏览了柳神的代码后,记下的一次半转载式笔记,不经感叹柳神的强大orz,这里给出柳神的题解地址:https://blog.csdn.net/liuchuo/article/detail ...

  9. 1022 Digital Library——PAT甲级真题

    1022 Digital Library A Digital Library contains millions of books, stored according to their titles, ...

随机推荐

  1. SpringBoot使用SpringDataJPA完成CRUD

    创建UserJPA接口并且继承SpringDataJPA内的接口作为父类: UserJPA继承了JpaRepository接口(SpringDataJPA提供的简单数据操作接口).JpaSpecifi ...

  2. 学习笔记 Hadoop的job提交过程,shuffle过程以及HA机制的实现

    一,在hadoop中的mapreduce的job提交过程比较繁琐,但掌握job的提交过程是我们进入深入学习的必要. 二,mapreduce的shuffle机制 三,Hadoop的HA机制.

  3. Dedecms织梦搜索页显示条数的更改方法

    织梦dedecms搜索结果页面的显示条数默认是10条,这个数值在模板当中是不能控制的. 解决方法: 打开根目录下的plus文件夹,找到search.php修改一段代码: 在大概第15行,找到 $ pa ...

  4. shell脚本的使用该熟练起来了,你说呢?(篇二)

    继续前一篇的文章: shell脚本的使用该熟练起来了,你说呢?(篇一) 作者:良知犹存 转载授权以及围观:欢迎添加微信公众号:羽林君 shell传递参数 shell传递参数 我们可以在执行 Shell ...

  5. std::thread线程库详解(4)

    目录 目录 前言 条件变量 一些需要注意的地方 总结 前言 本文主要介绍了多线程中的条件变量,条件变量在多线程同步中用的也比较多.我第一次接触到条件变量的时候是在完成一个多线程队列的时候.条件变量用在 ...

  6. P3195 [HNOI2008] 玩具装箱(斜率优化DP)

    题目链接 设\(d[i]\)为将前 \(i\) 个玩具装入箱中所需得最小费用 容易得到动态转移方程: \[d[i] = min(d[j] + (s[i]-s[j]+i-j-1-L)^2), (j< ...

  7. 【bzoj 2467】[中山市选2010]生成树(数论--排列组合)

    题目:有一种图形叫做五角形圈.一个五角形圈的中心有1个由n个顶点和n条边组成的圈.在中心的这个n边圈的每一条边同时也是某一个五角形的一条边,一共有n个不同的五角形.这些五角形只在五角形圈的中心的圈上有 ...

  8. HDU 3537 Daizhenyang's Coin 翻硬币博弈

    题意: 给你n个硬币,你可以从中拿出来1.2.3个硬币,它们不一定要连续,你只需要保证拿出来的硬币中那个下标最大的硬币一定要是正面朝上,最后谁不能操作,谁就输了 题解: 翻硬币游戏 结论: 局面的SG ...

  9. Codeforces Round #633 div2 A~C

    A. Filling Diamonds 题意:给你n个菱形方块,问能构成图示形状的有多少种 题解:自己画几个不难发现答案是n 代码: 1 #include <iostream> 2 #in ...

  10. H5网页应用打包安卓App (全网最详细教程)

    img { box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15) !important } .red { color: rgba(255, 0, 0, 1) } ...