zoukankan      html  css  js  c++  java
  • L1-043 阅览室

    L1-043 阅览室 (20分)
     

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

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

    输入格式:

    输入在第一行给出一个正整数N(≤10),随后给出N天的纪录。每天的纪录由若干次借阅操作组成,每次操作占一行,格式为:

    书号([1, 1000]内的整数) 键值SE) 发生时间hh:mm,其中hh是[0,23]内的整数,mm是[0, 59]内整数)

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

    输出格式:

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

    输入样例:

    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

    感觉还是有点难的吧,首先是时间计算,输入的时候输入的时间很是麻烦,时间减法也不好解决,干脆就直接换算成分钟,然后直接做减法就行,方便多了。

    然后是所谓的借书还书问题,我又直接用一个大数组解决算了,实际上还是挺方便的,最后看借书还书和时间问题都需要大数组就直接做了个结构体放进去了。

    最后两重循环解决问题,第一重解决天数、书籍总数这些问题,二重循环就解决借书还书,时间问题就可以了。最后按照要求进行对应输出,解决。

    哦,还有,最后的时间,他是有明确的要求的,需要精确,这时候发现printf挺好用的,爱了。

    //#include<bits/stdc++.h> 
    #include <iostream>
    #include <cstring>
    #include <string>
    #include <iomanip>        // 格式化输入输出 
    #include <cmath>
    #include <cstdlib> 
    #include <vector>
    
    #define jie 'S'
    #define huan 'E' 
    
    using namespace std;
    
    struct Time {
        char ch = ' ';
        int number = 0;
    };
    
    int Function_042( ) {
    
    }
    // 一个a[1000],然后一个时间统计,打算用struct 
    int main()
    {
        int n,book_d,book_m,book_k;
        char cchh,c;
        cin>>n;
        Time time[1001];
        for(int day_i = 0;day_i < n;day_i++) {
            int sum_time = 0;
            int sum_book = 0;
            while(1) {
                cin>>book_k>>cchh>>book_d>>c>>book_m;
                if(book_k == 0)
                    break;
                int t = book_d * 60 + book_m;
                if(cchh == 'S') {
                    time[book_k].ch = 'S';
                    time[book_k].number = t;
                }
                if(cchh == 'E' && time[book_k].ch == 'S') {
                    sum_book++;
                    sum_time += t - time[book_k].number;
                    time[book_k].ch = ' ';
                    time[book_k].number = 0;
                }
            }
            if(sum_book != 0)
                printf("%d %0.f
    ",sum_book,sum_time / (double)sum_book);
            else
                cout<<0<<' '<<0<<endl;
        }
        return 0;
    }
  • 相关阅读:
    shell脚本学习(1)列出一组IP内所有活动主机
    中兴ZXR10 GER4核心路由器配置案例
    中兴ZXR10 6905核心交换机配置案例
    NFS笔记(二)NFS服务器配置实例
    NFS笔记(一)NFS服务器工作原理及详细配置
    CentOS7.3下关于DHCP中继代理服务器的详细配置
    CentOS6下DHCP服务(二)简单配置案例及故障排查
    impdp 多个表空间到1个表空间通配符的使用
    11.2.0.4 has 启动失败
    oracle 11g 添加删除haip
  • 原文地址:https://www.cnblogs.com/2015-16/p/13540523.html
Copyright © 2011-2022 走看看