题目链接: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;
}
}