博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
1013.开门人和关门人
阅读量:4325 次
发布时间:2019-06-06

本文共 1175 字,大约阅读时间需要 3 分钟。

题目描述:
    每天第一个到机房的人要把门打开,最后一个离开的人要把门关好。现有一堆杂乱的机房签到、签离记录,请根据记录找出当天开门和关门的人。
输入:

    测试输入的第一行给出记录的总天数N ( N> 0 ),下面列出了N天的记录。 

    每天的记录在第一行给出记录的条目数M (M > 0 ),下面是M行,每行的格式为 
    证件号码 签到时间 签离时间 
    其中时间按“小时:分钟:秒钟”(各占2位)给出,证件号码是长度不超过15的字符串。

输出:

    对每一天的记录输出1行,即当天开门和关门人的证件号码,中间用1空格分隔。 

    注意:在裁判的标准测试输入中,所有记录保证完整,每个人的签到时间在签离时间之前,且没有多人同时签到或者签离的情况。

样例输入:
31ME3021112225321 00:00:00 23:59:592EE301218 08:05:35 20:56:35MA301134 12:35:45 21:40:423CS301111 15:30:28 17:00:10SC3021234 08:00:00 11:25:25CS301133 21:45:00 21:58:40
样例输出:
ME3021112225321 ME3021112225321EE301218 MA301134SC3021234 CS301133

 

#include
#include
using namespace std;struct record{ char id[20]; char arrive[15]; char leave[15];};record a[100];bool com1(record p,record q){ for(int i=0;i<8;i++){ if(p.arrive[i]!=q.arrive[i]) return p.arrive[i]
q.leave[i]; }}int main(){ int n,i,m,j; cin>>n; for(i=0;i
>m; for(j=0;j
>a[j].id>>a[j].arrive>>a[j].leave; } sort(a,a+j,com1); cout<
<<" "; sort(a,a+j,com2); cout<
<

 

转载于:https://www.cnblogs.com/bernieloveslife/p/9736627.html

你可能感兴趣的文章
生产订单“生产线别”带入生产入库单
查看>>
crontab导致磁盘空间满问题的解决
查看>>
java基础 第十一章(多态、抽象类、接口、包装类、String)
查看>>
Hadoop 服务器配置的副本数量 管不了客户端
查看>>
欧建新之死
查看>>
C程序之修改Windows的控制台颜色(转载)
查看>>
自定义滚动条
查看>>
[QT][待解决问题]对话框ui载入卡顿问题
查看>>
jquery中单选选中及清除选中状态
查看>>
APP开发手记01(app与web的困惑)
查看>>
笛卡尔遗传规划Cartesian Genetic Programming (CGP)简单理解(1)
查看>>
mysql 日期时间运算函数(转)
查看>>
初识前端作业1
查看>>
为啥程序会有bug?
查看>>
跨域技术
查看>>
JS里的居民们7-对象和数组转换
查看>>
计算两个日期的时间间隔,返回的是时间间隔的日期差的绝对值.
查看>>
python初体验
查看>>
配置vue,vue脚手架的应用(老版本)
查看>>
Start with PJSIP on windows
查看>>