您的位置:首页 > 其它

hdu 1201 18岁生日

2016-02-28 08:25 253 查看
题目链接:hdu 1201

思路:先不处理闰年的情况,后期处理闰年。

#include<iostream>
#include<cstdio>
using namespace std;
bool isLeap(int y)
{
bool ret  = false;
if(y%4==0&&y%100!=0||y%400==0) ret = true;
return ret;
}
int main()
{
int t,y,m,d,sum;
cin>>t;
while(t--)
{
scanf("%d-%d-%d",&y,&m,&d);
if(isLeap(y)&&m==2&&d==29)
{
cout<<-1<<endl;
continue;
}
sum = 18 *365;
for(int i=y+1;i<y+18;i++) if(isLeap(i)) sum++;
if(isLeap(y)&&m<=2) sum++;
if(isLeap(y+18)&&m>2||isLeap(y+18)&&m==2&&d==29) sum++;
cout<<sum<<endl;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: