[恢]hdu 1201

2011-12-16 03:49:11

地址:http://acm.hdu.edu.cn/showproblem.php?pid=1201

题意:中文。

代码:

# include <stdio.h>


int IsLeap(int y){return y%4==0 && y%100!=0 || y%400==0;}
int days(int y, int m, int d)
{
int month[2][13] = {
{0, 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334},
{0, 0, 31, 60, 91, 121, 152, 182, 213, 244, 274, 305, 335}} ;
return month[IsLeap(y)][m]+d ;
}


int main ()
{
int T, i ;
int y, m, d ;
int ans ;
scanf ("%d", &T) ;
while (T--)
{
scanf ("%d-%d-%d", &y, &m, &d) ;
if (m == 2 && d == 29 && !IsLeap(y+18))
{
puts ("-1") ;
continue ;
}
ans = 0 ;
for (i = y ; i < y+18 ; i++)
ans += IsLeap(i) ? 366 : 365 ;
ans += days(y+18, m, d) ;
ans -= days(y, m, d) ;
printf ("%d\n", ans) ;
}
return 0 ;
}



posted @ 2012-01-06 16:42  Seraph2012  阅读(158)  评论(0编辑  收藏  举报