• hdu 1201


    18岁生日

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


    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 #include <iostream>
     2 #include <cstdlib>
     3 #include <cstdio>
     4 #include <cstring>
     5 
     6 using namespace std;
     7 
     8 bool leap(int n)
     9 {
    10     if (n%400==0 || (n%4==0 && n%100!=0))
    11         return true;
    12     else return false;
    13 }
    14 
    15 int main(void)
    16 {
    17     int t, y, m, d;
    18 #ifndef ONLINE_JUDGE
    19     freopen("18.in", "r", stdin);
    20 #endif
    21     scanf("%d", &t);
    22     while (t--)
    23     {
    24         scanf("%d-%d-%d", &y, &m, &d);
    25         if (leap(y)&&(m==2)&&(d==29))
    26         {
    27             printf("-1\n"); continue;
    28         }
    29         int sum = 0;
    30         for (int i = 1; i <= 17; ++i)
    31             if (leap(i+y))
    32                 sum += 366;
    33             else sum += 365;
    34         sum += 365;
    35         if (leap(y) && (m<2 || (m==2&&d<=29)))
    36             sum++;
    37         if (leap(y+18) && (m>2 || (m==2&&d==29)))
    38             sum++;
    39         printf("%d\n", sum);
    40     }
    41 
    42     return 0;
    43 }

    看的人家的代码才搞定……简洁,准确,代码要多练,才能精简

  • 相关阅读:
    K8S集群组件
    K8S概念
    yaml格式
    Linux下升级openssl
    cpu的核心数及线程关系
    bzoj4941: [Ynoi2016]镜子里的昆虫
    bzoj4940: [Ynoi2016]这是我自己的发明
    bzoj4939: [Ynoi2016]掉进兔子洞
    bzoj4867: [Ynoi2017]舌尖上的由乃
    bzoj 4866: [Ynoi2017]由乃的商场之旅
  • 原文地址:https://www.cnblogs.com/liuxueyang/p/2870765.html
Copyright © 2020-2023  润新知