20岁生日
来源:互联网 发布:龙珠刷人气软件 编辑:程序博客网 时间:2024/04/30 17:23
题目描述
路过这的20岁生日就要到了,他当然很开心,可是他突然想到一个问题,是不是每个人从出生开始,到达20岁生日时所经过的天数都是一样的呢?似乎并不全都是这样,所以他想请你帮忙计算一下他和他的几个朋友从出生到达20岁生日所经过的总天数,让他好来比较一下。
输入
一个数T,后面T行每行有一个日期,格式是YYYY-MM-DD。如我的生日是1988-03-07。
输出
T行,每行一个数,表示此人从出生到20岁生日所经过的天数。如果这个人没有20岁生日,就输出-1。
样例输入
11988-03-07
样例输出
7305
#include<stdio.h>
int main()
{
int year,mon,day,sum1,sum2,sum3,t,i,flag1,flag2;
scanf("%d",&t);
while(t--)
{
flag1=flag2=0;
int a[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
scanf("%d-%d-%d",&year,&mon,&day);
sum1=sum2=sum3=0;
for(i=year+1;i<year+20;i++)
{
if(i%4==0&&i%100!=0||i%400==0)
sum1+=366;
else
sum1+=365;
}
if(year%4==0&&year%100!=0||year%400==0)
a[2]=29,flag1=1;
for(i=mon+1;i<13;i++)
sum2=sum2+a[i];
sum2=sum2+a[mon]-day;
a[2]=28;
if((year+20)%4==0&&(year+20)%100!=0||(year+20)%400==0)
a[2]=29,flag2=1;
for(i=1;i<mon;i++)
sum3=sum3+a[i];
if(flag1&&!flag2&&mon==2&&day==29)
printf("-1\n");
else
printf("%d\n",sum1+sum2+sum3+day);
}
return 0;
}
阅读全文
0 0
- 昨天20岁生日
- NYOJ312 20岁生日
- 18,20岁生日
- 312 20岁生日
- 20岁生日
- NYOJ-20岁生日
- nyoj312 20岁生日
- 20岁生日
- 20岁生日
- 20岁生日
- NYOJ 312 20岁生日
- NYOJ 312 20岁生日
- nyoj-312-20岁生日
- NYOJ 312 20岁生日
- NYOJ 312-20岁生日
- nyoj 312 20岁生日
- NYOJ 312 20岁生日
- NYOJ 312 20岁生日
- 相隔一段时间之后才可以执行某一事件的功能实现
- 完美解决SwipeRefreshLayout与WebView冲突
- leetcode--第5章--树-5.1二叉树的遍历--5.1.1 binary tree preorder traversal
- Git(二)
- JS常识总结20170727
- 20岁生日
- gcc的__attribute__((section(“”)))属性含义
- NOIP2016 T6 愤怒的小鸟
- C
- Tex中的表格列的宽度控制
- react-redux基础
- 杭电暑期多校集训—Regular polygon
- SQL Server CONVERT() 函数
- Leetcode85. Maximal Rectangle.