题目名字
[题目链接](https://pintia.cn/problem-sets/994805046380707840/problems/994805087447138304
题意
天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下S键,程序开始计时;当读者还书时,管理员输入书号并按下E键,程序结束计时。书号为不超过1000的正整数。当管理员将0作为书号输入时,表示一天工作结束,你的程序应输出当天的读者借书次数和平均阅读时间。
注意:由于线路偶尔会有故障,可能出现不完整的纪录,即只有S没有E,或者只有E没有S的纪录,系统应能自动忽略这种无效纪录。另外,题目保证书号是书的唯一标识,同一本书在任何时间区间内只可能被一位读者借阅。
思路
依次寻找借书的人的借书时间和还书时间,计算借书时间和次数,最后再算一下平均时间
坑点
- 可能存在借书不换,还书没借的情况,要舍去
- 平均阅读时间(以分钟为单位的精确到个位的整数时间)
实现步骤
1.定义数组存放每个人的借书时间
2.定义一个标识确认书借了有没有还
3.跳过错误情况
代码
`
#include<iostream>
using namespace std;
int main(){
int N,n,hh,mm;
cin>>N;
char c;
for(int i=0;i<N;i++)
{
int flag[1001]={0},time[1001]={0},sum=0,cnt=0;
while(scanf("%d %c %d:%d",&n,&c,&hh,&mm))
{
if(n==0) break;//不存在0号书
if(c=='S')//借书
{
time[n]=hh*60+mm;//记录借书时间
flag[n]=1;//标记已经借到了
}
else if(c=='E')//还书
{
if(flag[n]==1)
{
flag[n]=0;//标记已经还了
sum+=hh*60+mm-time[n];//记录一共借书多久
cnt++;//有借有还
}
}
}
if(cnt==0) printf("0 0\n");//没人借书
else printf("%d %.0f\n",cnt,(double)sum/cnt);//平均阅读时间(以分钟为单位的精确到个位的整数时间)
}
return 0;
}