题18.天梯赛训练-L1-043 阅览室 (20 分)

本文详细解析了C++实现的天梯赛训练-L1-043阅览室问题,重点在于理解借书次数的计算和借书时长的处理,包括借书(flag置为1)和还书(flag置为0)的状态转换,以及平均借阅时长的四舍五入计算方法。代码中通过map数据结构管理书籍的借还状态,并输出借书人数和平均借阅时长的整数部分。
摘要由CSDN通过智能技术生成


题18.天梯赛训练-L1-043 阅览室 (20 分)


一、题目

在这里插入图片描述

在这里插入图片描述

二、题解

本题的关键在于借书次数增加以及借书时长生成需要有借(flag置为1)有还(flag置为0),以及注意aver的四舍五入(aver=(float)sum/n+0.5)。

#include <bits/stdc++.h>

using namespace std;

int main()
{
    int N;
    int d=1;
    int i,n,num,sum;
    int h,mi;
    float aver;
    char key;
    cin>>N;
    while(d<=N)
    {
        n=0;
        sum=0;
        map<int,int> flag;
        map<int,int> s,e;
        cin>>num>>key;
        scanf("%d:%d",&h,&mi);
        while(num!=0)
        {
            if(key=='E'&&flag[num]==1)
            {
                e[num]=(h*60)+mi;
                sum+=e[num]-s[num];
                flag[num]=0;
                n++;
            }
            if(key=='S')//这个地方我先前写的是附加了条件flag[num]==0表示记录的是第一次输入S的数据,因为我觉得按照题目意思--从管理员按下S开始计时,应该是这样,但是测试点1错了,于是改成了这个,也就是从输入了一堆S的最后一个来记,但是我还是想不明白。。。
            {
                s[num]=(h*60)+mi;
                flag[num]=1;
            }
            cin>>num>>key;
            scanf("%d:%d",&h,&mi);
        }
        if(n!=0)
        {
            aver=(float)sum/n+0.5;
            printf("%d %d\n",n,(int)aver);
        }
        else
        {
            cout<<"0 0"<<endl;
        }
        d++;
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值