HDU-1201,18岁生日

简介: HDU-1201,18岁生日

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


程序代码:


#include<bits/stdc++.h>//写个万能头,嘿嘿嘿 
using namespace std;
bool LeapYear(int year)
{
  if(year%400==0||(year%4==0&&year%100!=0))
    return true;
  return false;
}
int main()
{
  int t,y,year,month,day,sum;
  scanf("%d",&t);
  while(t--)
  {
    scanf("%d-%d-%d",&year,&month,&day);
    if(month==2&&day==29)//2月29日出生的没有18岁生日,直接输出-1 
      printf("-1\n");
    else
    {
      sum=0;
      if(month<=2)//因为2月的天数有闰年和平年之分,所以这是一个分界点 
      {
        for(y=year;y<=year+17;y++)//月份小于等于2,该年的平或润 决定过一岁度过的天数
        {
          if(LeapYear(y))
            sum+=366;
          else
            sum+=365;
        }
      }
      else if(month>=3)//月份大于2,该年后一年的平或润 决定过一岁度过的天数
      {
        for(y=year+1;y<=year+18;y++)
        {
          if(LeapYear(y))
            sum+=366;
          else
            sum+=365;
        }
      }
      printf("%d\n",sum);
    }
  }
  return 0;
}


相关文章
|
6月前
|
Java
hdu 1263 水果
hdu 1263 水果
28 0
|
6月前
|
机器学习/深度学习 Java
hdu 1284钱币兑换问题
hdu 1284钱币兑换问题
27 0
|
7月前
|
8月前
|
C++
洛谷P1055 ISBN号码(C++解法)
洛谷P1055 ISBN号码(C++解法)
104 0
|
10月前
|
数据采集 程序员 Python
【每周一坑】特殊的生日
好吧,我在跳票的道路上又双叒叕前进了一步……今天终于厚着脸皮来更新【每“周”一坑】啦。感谢在后台孜孜不倦催促我的同学们
|
C++
蓝桥杯练习题一 - 生日蜡烛(c++)
蓝桥杯练习题一 - 生日蜡烛(c++)
119 0
蓝桥杯---棋盘放麦子.猜生日
蓝桥杯---棋盘放麦子.猜生日
HDOJ 1201 18岁生日
HDOJ 1201 18岁生日
92 0
Leetcode打卡 | No.017 电话号码的字母组合
欢迎和小詹一起定期刷leetcode,每周一和周五更新一题,每一题都吃透,欢迎一题多解,寻找最优解!这个记录帖哪怕只有一个读者,小詹也会坚持刷下去的!
79 0
Leetcode打卡 | No.017 电话号码的字母组合