L1-043 阅览室(模拟)

天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下 S 键,程序开始计时;当读者还书时,管理员输入书号并按下 E 键,程序结束计时。书号为不超过1000的正整数。当管理员将0作为书号输入时,表示一天工作结束,你的程序应输出当天的读者借书次数和平均阅读时间。

注意:由于线路偶尔会有故障,可能出现不完整的纪录,即只有 S没有 E,或者只有 E 没有 S 的纪录,系统应能自动忽略这种无效纪录。另外,题目保证书号是书的唯一标识,同一本书在任何时间区间内只可能被一位读者借阅。

输入格式:

输入在第一行给出一个正整数 $N(≤10)$,随后给出 $N$ 天的纪录。每天的纪录由若干次借阅操作组成,每次操作占一行,格式为:书号([1, 1000]内的整数) 键值SE发生时间hh:mm ,其中 hh 是[0,23]内的整数,mm 是[0, 59]内整数)

每一天的纪录保证按时间递增的顺序给出。

输出格式:

对每天的纪录,在一行中输出当天的读者借书次数和平均阅读时间(以分钟为单位的精确到个位的整数时间)。

输入样例:

1
2
3
4
5
6
7
8
9
10
11
12
3
1 S 08:10
2 S 08:35
1 E 10:00
2 E 13:16
0 S 17:00
0 S 17:00
3 E 08:10
1 S 08:20
2 S 09:00
1 E 09:20
0 E 17:00

输出样例:

1
2
3
2 196
0 0
1 60

思路:

创建一个结构体,time为存书的借出时间,flag判断书是否已经借出,然后在每次还书时更新总时间。注意最后的结果需要四舍五入。

代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#include <bits/stdc++.h>
using namespace std;

int N, id, hh, mm, sum = 0, temp, cnt = 0;
char space, c;
double aver;

struct books
{
int time;
int flag = 0;
}b[1005];

double round(double d){return (d > 0.0) ? floor(d+0.5) : ceil(d-0.5);}

int main()
{
scanf("%d", &N);
while(N > 0)
{
scanf("%d%c%c%d:%d", &id, &space, &c, &hh, &mm);
if(id == 0)
{
N--;
if(cnt == 0)
printf("0 0\n");
else
{
aver = 1.0 * sum / cnt;
printf("%d %d\n", cnt, (int)round(aver));
}
cnt = sum = 0;
continue;
}
temp = hh * 60 + mm;
if(c == 'S')
{
b[id].time = temp;
b[id].flag = 1;
}
else if(c == 'E' && b[id].flag == 1)
{
sum += temp - b[id].time;
b[id].flag = 0;
cnt++;
}
}

return 0;
}