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. 函数式编程(logging日志管理模块)

    本节内容 日志相关概念 logging模块简介 使用logging提供的模块级别的函数记录日志 logging模块日志流处理流程 使用logging四大组件记录日志 配置logging的几种方式 向日 ...

  2. Python Package(转)

    http://www.cnpythoner.com/post/2.html python中的Module是比较重要的概念.常见的情况是,事先写好一个.py文 件,在另一个文件中需要import时,将事 ...

  3. 最近公共祖先(LCA)---tarjan算法

    LCA(最近公共祖先).....可惜我只会用tarjan去做 真心感觉tarjan算法要比倍增算法要好理解的多,可能是我脑子笨吧略略略 最近公共祖先概念:在一棵无环的树上寻找两个点在这棵树上深度最大的 ...

  4. BZOJ2882 工艺【SAM】 最小循环串

    BZOJ2882 工艺 给出一个串,要求其循环同构串中字典序最小的那个 串翻倍建\(SAM\)然后从起点开始贪心的跑\(n\)次即可 当然也能用最小表示法来做 #include<bits/std ...

  5. 【uva 12219】Common Subexpression Elimination(图论--树+自定义比较器+映射+递归)

    题意:如题,用表达式树来表示一个表达式,且消除公共的部分,即用编号表示.编号 K 定义为表达式第 K 个出现的字符串. 解法:先构造表达式树,给每棵子树用(string,left_son,right_ ...

  6. Codeforces Round #669 (Div. 2) A. Ahahahahahahahaha (构造)

    题意:有一个长度为偶数只含\(0\)和\(1\)的序列,你可以移除最多\(\frac{n}{2}\)个位置的元素,使得操作后奇数位置的元素和等于偶数位置的元素和,求新序列. 题解:统计\(0\)和\( ...

  7. Java对象延迟初始化的实现

    一.什么是延迟初始化? 在Java多线程程序中,有时候需要采用延迟初始化来降低初始化类和创建对象的开销. 延迟初始化实际上就是:当我们要进行一些高开销的对象初始化操作时,只有在使用这些对象时才进行初始 ...

  8. 实战交付一套dubbo微服务到k8s集群(5)之使用Jenkins进行持续构建交付dubo服务的提供者

    1.登录到jenkins,新建一个项目 2.新建流水线 3.设置保留的天数及份数 4.添加第一个参数:设置项目的名称 5.添加第二个参数:docker镜像名称 6.添加第三个参数:项目所在的git中央 ...

  9. Kubernets二进制安装(11)之部署Node节点服务的kubelet

    集群规划 主机名 角色 IP地址 mfyxw30.mfyxw.com kubelet 192.168.80.30 mfyxw40.mfyxw.com kubelet 192.168.80.40 注意: ...

  10. Redis性能指标监控

    监控指标 •性能指标:Performance•内存指标: Memory•基本活动指标:Basic activity•持久性指标: Persistence•错误指标:Error 性能指标:Perform ...