zoukankan      html  css  js  c++  java
  • 『ACM C++』 PTA 天梯赛练习集L1 | 042-43

    记录刷题情况

    ------------------------------------------------L1-042----------------------------------------------------------

    L1-042 日期格式化

    世界上不同国家有不同的写日期的习惯。比如美国人习惯写成“月-日-年”,而中国人习惯写成“年-月-日”。下面请你写个程序,自动把读入的美国格式的日期改写成中国习惯的日期。

    输入格式:

    输入在一行中按照“mm-dd-yyyy”的格式给出月、日、年。题目保证给出的日期是1900年元旦至今合法的日期。

    输出格式:

    在一行中按照“yyyy-mm-dd”的格式给出年、月、日。

    输入样例:

    03-15-2017

    输出样例:

    2017-03-15

    ------------------------------------------------L1-042----------------------------------------------------------

    注解:神级水题,用scanf 和 printf会异常方便。

    #include<stdio.h>
    
    int main()
    {
        int mm,dd,yyyy;
        scanf("%d-%d-%d",&mm,&dd,&yyyy);
        printf("%04d-%02d-%02d",yyyy,mm,dd);
        return 0;
    }

    知识注解

      %04d 意思是为其用0填充补满4位

    ------------------------------------------------L1-043----------------------------------------------------------

    L1-043 阅览室

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

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

    输入格式:

    输入在第一行给出一个正整数N(≤),随后给出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

    ------------------------------------------------L1-043----------------------------------------------------------

    注解:该题唯一要注意的是四舍五入的坑点,务必检查输出的上下界。

    #include<stdio.h>
    #include<math.h>
    #include<string.h>
    int times;
    int count = 0;
    int start[10001];
    int sum,ans;
    int brrow;
    int main()
    {
        scanf("%d",&times);
        for(int i = 0;i<1001;i++) start[i] = -1;
        while(1)
        {
            if(count == times) break;
            int book,hours,minutes;
            char type;
            scanf("%d %c %d:%d",&book,&type,&hours,&minutes);
            if(book == 0) 
            {
                if(brrow!=0) ans=(sum+(brrow/2))/brrow;
                printf("%d %d
    ",brrow,ans);
                for(int i = 0;i<1001;i++) start[i] = -1;
                sum = brrow = ans = 0;
                count++;
                continue;
            }
            if(type == 'S') start[book] = hours*60+minutes;
            else if(type == 'E' && start[book] != -1)
            {
                brrow++;
                sum = sum + (hours*60+minutes) - start[book];
                start[book] = -1;
            }
        }
        return 0;
     } 

    注:如果有更好的解法,真心希望您能够评论留言贴上您的代码呢~互相帮助互相鼓励才能成长鸭~~

  • 相关阅读:
    rabbitmq-高级(死信队列)
    rabbitmq-高级(TTL过期时间)
    springboot整合rabbitmq(topic主题模式)
    springboot整合rabbitmq(direct路由模式)
    glide图片加载库
    自己封装的OKhttp请求
    手机上搭建微型服务器
    listview实现点击条目上的箭头展开隐藏菜单。
    recycleview + checkbox 实现单选
    recycleview中使用checkbox导致的重复选中问题
  • 原文地址:https://www.cnblogs.com/winniy/p/10562357.html
Copyright © 2011-2022 走看看