L1-043 阅览室题目地址
天梯图书阅览室请你编写一个简单的图书借阅统计程序。当读者借书时,管理员输入书号并按下S键,程序开始计时;当读者还书时,管理员输入书号并按下E键,程序结束计时。书号为不超过1000的正整数。当管理员将0作为书号输入时,表示一天工作结束,你的程序应输出当天的读者借书次数和平均阅读时间。
注意:由于线路偶尔会有故障,可能出现不完整的纪录,即只有S没有E,或者只有E没有S的纪录,系统应能自动忽略这种无效纪录。另外,题目保证书号是书的唯一标识,同一本书在任何时间区间内只可能被一位读者借阅。
输入格式:
输入在第一行给出一个正整数N(≤10),随后给出N天的纪录。每天的纪录由若干次借阅操作组成,每次操作占一行,格式为:
书号([1, 1000]内的整数) 键值(S或E) 发生时间(hh:mm,其中hh是[0,23]内的整数,mm是[0, 59]内整数)
每一天的纪录保证按时间递增的顺序给出。
输出格式:
对每天的纪录,在一行中输出当天的读者借书次数和平均阅读时间(以分钟为单位的精确到个位的整数时间)。
这题是骗子题啊,基本的数据处理。
1.看到图书馆,可以想到要用结构(狗头)。
2.题设给的很恶劣
(1)借相同书,计最后一个
(2)还相同书,计第一个,所以需要数组里有flag来判断是否是上下接壤的。
(3)由题干给的输入输出,196测试后可以判断需要四舍五入(有个疑问,之前看到一个帖子,进一法是什么,效果相同吗?)
(4)结构(局部变量)清零
#include<bits/stdc++.h>
struct o{
int bo;
int re;
int time;
int flag=0;
};
int main(void)
{
int n;int flag=0,cnt=0,sum=0,book=1,hour,min;//其实这里也可以改成局部,但是我懒;
char ch;
scanf("%d",&n);
while(n--)
{
struct o re[1050];//局部变量,循环后释放;
do
{
scanf("%d %c %d:%d",&book,&ch,&hour,&min);
if(book==0)break;
else
{
if(ch=='S') {
re[book].flag=1;
re[book].bo=hour*60+min;
}
else if(ch=='E'&&re[book].flag==1){
cnt++;
sum+=re[book].time=hour*60+min-re[book].bo;
re[book].flag=0;
}
}
}while(book!=0);
if(cnt!=0)
printf("%d %d\n",cnt,(int)(1.0*sum/cnt+0.5));
else printf("0 0\n");
cnt=0,sum=0,book=1;
}
return 0;
}
我回来了,时隔多日,之前在搞虚拟机和迁徙(没刷题,泪目),祝愿各位新春快乐!(递上一个塞着口罩的红包)