PAT甲级真题1006:签到与签出

简介: PAT甲级真题1006:签到与签出

PAT甲级真题1006:签到与签出

每天第一个到机房的人负责开门,最后一个从机房离开的人负责锁门。

现在,给定每个人的签到与签出记录,请你找出当天开门的人以及锁门的人分别是谁。

输入格式

第一行包含整数 M,表示共有 M 个人的签到签出记录。接下来 M行,每行的形式如下:

ID_number Sign_in_time Sign_out_time

时间以 HH:MM:SS 形式给出,ID_number 是一个长度不超过 15 的字符串。

输出格式

共一行,输出开门人和锁门人的ID_number,用一个空格隔开。

数据范围1≤M≤10,数据保证每个人的签到时间早于签出时间,并且不会出现两个人同时签到或同时签出的情况。

输入样例:
3
CS301111 15:30:28 17:00:10
SC3021234 08:00:00 11:25:25
CS301133 21:45:00 21:58:40
输出样例:
SC3021234 CS301133

解题思路

  • 定义一个结构体Person,包含ID_number、签到时间Sign_in_time和签出时间Sign_out_time。
  • 使用unordered_map存储每个人的签到时间和签出时间。
  • 将签到时间和签出时间转换为分钟数,方便后续排序。
  • 对签到时间和签出时间进行排序。
  • 输出最早签到的人的ID_number和最晚签出的人的ID_number。
  • 本题最关键的是对字符串的处理

stoi 函数

stoi函数

作用是将 n 进制的字符串转化为十进制,使用时包含头文件string.

定义如下:

int stoi( const std::string& str, std::size_t* pos = nullptr, int base = 10 );
参数:
str - 待转换的字符
pos - 其取值可以是一个空字符,在这种情况下,pos未被使用;另外如果pos不是空指针,函数将pos的值设置为str中数字后面的第一个字符的位置。
base - 字符中数字的进制,默认为10进制,如果base取值为0,则进制由字符串中的格式决定。
返回值:
如果转换成功的话,stoi函数将会把转换后的得到数字以int类型返回。
如果字符串中没有数字的话,将会抛出"invalid_argument"的异常;
如果字符串中的数字转换后超过int的范围,将会抛出"out_of_range"的异常;
因此使用stoi函数的时候最好加入异常处理。

substr substring 函数

两种方式

substr:返回一个从指定位置开始的指定长度的子字符串

substring:返回位于 String 对象中指定位置的子字符串。

stringvar.substr(start, [length])
/*
参数
stringvar   必选项。要提取子字符串的字符串文字或 String 对象。
start       必选项。所需的子字符串的起始位置。字符串中的第一个字符的索引为 0。
length      可选项。在返回的子字符串中应包括的字符个数。
说明
如果 length 为 0 或负数,将返回一个空字符串。如果没有指定该参数,则子字符串将延续到 stringvar 的最后。
*/
strVariable.substring(start, end)
/*
参数
start:指明子字符串的起始位置,该索引从 0 开始起算。
end:指明子字符串的结束位置,该索引从 0 开始起算。
说明
substring 方法将返回一个包含从 start 到最后(不包含 end )的子字符串的字符串。
substring 方法使用 start 和 end 两者中的较小值作为子字符串的起始点。
*/

AC代码

#include<vector>
#include <iostream>
#include <cstring>
#include <algorithm>
#include <unordered_map>
const int N = 11;
using namespace std;
struct Person
{
    string id;
    string si;
    string so;
}p[N];
int main()
{
    int m;
    cin>>m;
    for (int i = 0; i < m; i ++ )
    {
        cin>>p[i].id>>p[i].si>>p[i].so;
    }
    unordered_map<string,int> SiTime;
    for (int i = 0; i < m; i ++ )
    {
        SiTime[p[i].id]=stoi(p[i].si.substr(0,2))*60*60+stoi(p[i].si.substr(3,2))*60+stoi(p[i].si.substr(6,2));
    }
    unordered_map<string,int> SoTime;
    for (int i = 0; i < m; i ++ )
    {
        SoTime[p[i].id]=stoi(p[i].so.substr(0,2))*60*60+stoi(p[i].so.substr(3,2))*60+stoi(p[i].so.substr(6,2));
    }
    vector<pair<int,string>> SiMoning;
    for(auto item : SiTime)
    {
        SiMoning.push_back({item.second,item.first});
    }
    sort(SiMoning.begin(),SiMoning.end());
    string s1=SiMoning[0].second;
    vector<pair<int,string>> SiEvening;
    for(auto item : SoTime)
    {
        SiEvening.push_back({item.second,item.first});
    }
    sort(SiEvening.begin(),SiEvening.end());
    string s2=SiEvening[SiEvening.size()-1].second;
    cout << s1 << " " << s2 <<endl;
    return 0;
}


相关文章
|
8月前
蓝桥杯真题代码记录(卡片
蓝桥杯真题代码记录(卡片
61 0
|
8月前
蓝桥杯省赛冲刺(1 补充)考试流程 做题技巧 手算题 杂题
蓝桥杯省赛冲刺(1 补充)考试流程 做题技巧 手算题 杂题
40 0
|
小程序 容器
幼儿园核酸预约登记小程序实战开发(下篇)
我们上篇介绍了核酸检测小程序的需求分析及数据源设计,本篇我们介绍一下如何开发具体的功能。
幼儿园核酸预约登记小程序实战开发(下篇)
|
存储 小程序 数据库
幼儿园核酸预约登记小程序实战开发(上篇)
本篇以一个现实中的实际场景,核酸预约登记为例,讲解如何通过低代码工具来快速的开发一款小程序。介绍了需求分析的方法,如何做数据库设计,以及低码开发关键的开发步骤。案例详实,操作步骤丰富,适合零基础又想自己搭建小程序的同学学习参考。
幼儿园核酸预约登记小程序实战开发(上篇)
【刷穿 LeetCode】551. 学生出勤记录 I : 简单模拟题(附模拟题目录)
【刷穿 LeetCode】551. 学生出勤记录 I : 简单模拟题(附模拟题目录)
|
前端开发 Java 关系型数据库
假期第二天,给学弟写一个基于SSM框架图书馆预约占座系统
图书馆是学校信息化的重要场所,是科学研究的中心、图书中心、文献中心,高校的三大支柱之一。占座行为一直是图书馆管理的“心病”,乱占图书馆座位现象严重影响图书馆的管理。 为保证图书馆自习室座位与日益多的学生对于自习室座位的需求,对此需求开发出图书馆预约占座管理系统,本文解决了乱占座所导致的座位利用率不足的问题。
209 0
假期第二天,给学弟写一个基于SSM框架图书馆预约占座系统
|
Java 关系型数据库 MySQL
假期第二天,给老板写一个基于SSM框架的在线考试系统
本文主要是基于JSP+SSM+MySQL的开发模式。该系统采用Spring框架和Mybatis框架,将该两项技术进行整合,完成系统的开发,系统采用B/S的体系结构和免费的MySQL作为数据库服务器可以降低成本,服务器方面则选择了Apache旗下开源的Tomcat 8.0版本。该系统主要实现了考生的考试功能和后台管理功能。
231 0
假期第二天,给老板写一个基于SSM框架的在线考试系统
假期愉快!
之前在的文章中已经写了公平锁、非公平锁,独享锁、共享锁,那么接下来我们就得介绍互斥锁和读写锁了。那我们我就来了解一波把!
|
数据库 API
轻松实现驾考宝典等驾考项目答题界面
开源这个项目主要是想帮助更多想做驾考类项目的同志们参谋参谋,亦或是想做答题项目的,本项目实现了单选和复选的的混合,该项目配合的数据源是来自阿凡达,之前做驾考的时候,记得聚合数据也有的,后来关掉了,所以就用了阿凡达的,该接口每天可以请求1000次,感觉不算太多,但足够使用,如果运用到项目的话,安装应用的时候将所有题目缓存到数据库,以后取数据的时候就去数据库里面取数据,这样就方便
1865 0
|
安全 程序员 网络安全
2019年快来了,送给每位程序员一份新年计划清单
​ 一日之计在于晨,一年之计在于春,对于程序员来讲,挑战自我很重要。有创造力的以及技术性的休整是可行的。给自己的新年列个计划清单,一起在新的一年更好地成长吧! 进入真实生活 程序员们过分沉迷于数码设备,在数码设备之外也别有一番天地。