PTA L1-043 阅览室 C语言(附测试点说明)

题目1:

输入样例:


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

输出样例:


2 196
0 0
1 60

说一下测试点的坑:

测试点2,3没过可能是没有处理00:00这样的数据,比如:E 00:00 S 3:16 这组数据是需要处理的,还有就是平均阅读时间的四舍五入问题;

测试点1:一本书在未归还的情况下,被多次借出,则取最后一次借出时间;再者就是若有多次归还则取第一次归还时间。

代码:


#include <stdio.h>
#include <string.h>
//int sq(int q,int t)
//{
//    return (q/t)*t<q?(q/t+1):(q/t);
//}
int main()
{
    int arr[2][1016] = {0};
    int n = 0;
    scanf("%d",&n);
    getchar();//处理回车
    int sum = 0,count = 0;//sum是总时间,count是借书次数
    while(n)
    {
        int num = 0;//num是书号
        char ch = 'q';
        int hour = 0,minute = 0;
        scanf("%d %c ",&num,&ch);
        scanf("%d:%d",&hour,&minute);
        getchar();
        if(ch == 'S')
        {
            arr[0][num] = hour;
            arr[1][num] = minute;
            if(hour == 0)//00:00的输入做特殊处理
                arr[0][num] = -1;
        }
        if(num == 0)//num == 0,说明一天结束
        {
            n--;
            if(count != 0)
                printf("%d %d\n",count,(int)((double)sum/count+0.5));//注意四舍五入
            else
                printf("%d %d\n",count,sum);
            count = 0;//重置数据
            sum = 0;
            memset(arr,0,sizeof(arr));//数组的重置;没有也行,能过
            continue;
        }
        if(arr[0][num] != 0 && ch=='E')//注意判断过滤一些无效记录,无S就有E
        {
            if(arr[0][num]==-1)//将前面的特殊处理变回来
                arr[0][num] = 0;
            sum+= ((hour-arr[0][num])*60+minute-arr[1][num]);
            arr[0][num] = 0;
            arr[1][num] = 0;
            if(num != 0 )
                count++;
        }
    }
    return 0;
}

结果:

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值