• CSU


    手游世界里,如何才能变强呢?
    自古以来,强者无非三种:欧皇、肝帝、壕神。
    冰弦在2018年4月22日打开天梯榜,仰望着那一个个大佬,想统计一下他们都是属于哪一类人。
    在这个题目里,我们定义:

    如果一个玩家注册以来,平均每天的充值金额达到100元,我们认为他属于壕神。
    如果一个玩家注册以来,平均每天的在线时长达到12小时,我们认为他属于肝帝。
    如果一个玩家不符合以上两个条件,然而他又在天梯榜单上,我们认为这种不肝不氪的人属于欧皇。
    Input
    输入的第一行是一个正整数N(N≤1000),表示冰弦总共打算研究N位大佬。
    接下来一共N行,每一行描述了一位天梯上的大佬信息。
    每一行,首先是一个格式为yyyy-mm-dd的日期,表示该玩家的注册时间,然后是两个整数M(0≤M≤107)和T(0 < T≤107),分别表示该玩家的总充值数(单位:元)和总在线时长(单位:分钟)。
    保证玩家的注册时间是一个合法的日期,不晚于2018-04-22,且不早于2000-01-01。
    保证玩家的平均每日在线时长不超过24小时。

    Output
    对于输入的每一行,输出一行答案。

    如果该玩家是欧皇,则输出O
    如果该玩家是肝帝但不是壕神,则输出G
    如果该玩家是壕神但不是肝帝,则输出H
    如果该玩家既是肝帝又是壕神,则输出GH
    Sample Input
    4
    2018-04-12 0 100
    2017-04-22 100 365000
    2018-04-22 1000000 10
    2018-03-22 10000 23333
    Sample Output
    O
    G
    H
    GH
    Hint
    计算注册以来的总天数时,要计算注册当天以及今天(2018-04-22)。

    其实就是计算天数,注意单位是分钟,要换算成小时再计算,注意题目包括注册当天
    天数计算分为三类,2018年内,2017年,2017年 之前
    于是年内的直接计算月份,2017年的计算2017年的剩余天数+2018年的固定天数(112天)
    2017年之前的计算2017年之前的年份所有天数求和+2017年固定天数和2018年固定天数(477天)

    #include<stdio.h>
    #include<string.h>
    #include<algorithm>
    #include<math.h>
    using namespace std;
    const int maxn=1003;
    int ping[13]= {0,31,28,31,30,31,30,31,31,30,31,30,31};
    int run[13]= {0,31,29,31,30,31,30,31,31,30,31,30,31};
    int n;
    double t,money;
    int yeardays(int y)
    {
        if((y%4==0&&y%100!=0)||(y%400==0)) return 366;
        else return 365;
    }
    int main()
    {
        int y,m,d,sum;
        scanf("%d",&n);
        for(int i=0; i<n; i++)
        {
            sum=0;
            scanf("%d-%d-%d",&y,&m,&d);
            scanf("%lf%lf",&money,&t);
    //            printf("====%d  %d  %d   %d  %d
    ",y,m,d,money,t);
            if(y==2018)
            {
                if(m==4)sum=22-d+1;
                else
                {
                    for(int i=m+1; i<4; i++)sum+=ping[i];
                    sum+=ping[m]-d+22+1;
                }
            }
            else if(y==2017)
            {
                for(int i=1; i<m; i++)sum+=ping[i];
                sum+=d;
                sum=365-sum+112+1;
            }
            else
            {
                if((y%4==0&&y%100!=0)||(y%400==0))
                {
                    for(int i=1; i<m; i++)sum+=run[i];
                    sum+=d;
                    sum=366-sum;
                    for(int i=y+1; i<2017; i++)sum+=yeardays(i);
                    sum+=477+1;
                }
                else
                {
                    for(int i=1; i<m; i++)sum+=ping[i];
                    sum+=d;
                    sum=365-sum;
                    for(int i=y+1; i<2017; i++)sum+=yeardays(i);
                    sum+=477+1;
                }
            }
            bool G=false;
            bool H=false;
            if(money/sum>=100)H=true;
            if(t/60.0/sum>=12)G=true;
            if(G&&H)printf("GH
    ");
            else if(G==false&&H)printf("H
    ");
            else if(G&&H==false)printf("G
    ");
            else printf("O
    ");
        }
    }
    
  • 相关阅读:
    Asp.net MVC 利用 Nopi 导出 Excel
    React 中 调用 Asp.net WebApi
    Node.js mysql 连接池使用事务自动回收连接
    __far和__near的小问题
    注册博客园了,以后在这里写写随笔。
    Electron客户端开发入门必备的知识点
    公司组织构架的三大类型
    经济学中的人性抉择(下)
    经济学中的人性抉择(上)
    模拟音乐播放器播放条样式
  • 原文地址:https://www.cnblogs.com/kuronekonano/p/11135745.html
Copyright © 2020-2023  润新知