• hdoj 1201 18岁生日


    18岁生日

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
    Total Submission(s): 23314    Accepted Submission(s): 7461


    Problem Description
    Gardon的18岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达18岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达18岁生日所经过的总天数,让他好来比较一下。
     

     

    Input
    一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
     

     

    Output
    T行,每行一个数,表示此人从出生到18岁生日所经过的天数。如果这个人没有18岁生日,就输出-1。
     

     

    Sample Input
    1
    1988-03-07
     

     

    Sample Output
    6574
    1、注意判断闰年
    2、当生日是02 29时要判断18岁那年是否为闰年如果不是闰年则无18岁生日
    #include<stdio.h>
    #include<string.h>
    int run(int x)
    {
        if(x%4==0&&x%100!=0||x%400==0)
        return 1;
        return 0;
    }
    int main()
    {
        int n,j,i,s,t,l,sum;
        int y,m,d;
        int s1[14]={0,31,28,31,30,31,30,31,31,30,31,30,31};
        int s2[14]={0,31,29,31,30,31,30,31,31,30,31,30,31};
        scanf("%d",&n);
        while(n--)
        {
            scanf("%d-%d-%d",&y,&m,&d);
            if(!run(y+18))
            {
                if(m==2&&d==29)
                {
                    printf("-1
    ");
                    continue;
                }
            }
            s=0;
            for(i=y;i<y+18;i++)
            {
                if(run(i))
                s+=366;
                else
                s+=365;
            }
            if(run(y+18))
            {
                //s+=366;
                for(i=1;i<m;i++)
                {
                    s+=s2[i];
                }
                s+=d;
            }
            else
            {
                //s+=365;
                for(i=1;i<m;i++)
                {
                    s+=s1[i];
                }
                s+=d;
            }
            sum=0;
            if(run(y))
            {
                for(i=1;i<m;i++)
                {
                    sum+=s2[i];
                }
                   sum+=d;
            }
            else
            {
                for(i=1;i<m;i++)
                {
                    sum+=s1[i];
                }
                sum+=d;
            }
            printf("%d
    ",s-sum);
        }
        return 0;
    }
    
  • 相关阅读:
    数据库水平切分(拆库拆表)的实现原理解析(转)
    json序列化 & 反序列化
    数据库工作原理
    【原创】python多线程测试接口性能
    XML解析(DOM、ElementTree)及转换为JSON
    nginx+supervisor+gunicorn+flask
    3、爬取干货集中营的福利图片
    Python多环境扩展管理
    九、frp对外提供简单的文件访问服务
    八、frps服务端与nginx可共用80端口
  • 原文地址:https://www.cnblogs.com/tonghao/p/4674401.html
Copyright © 2020-2023  润新知