题目75-日期计算
2014-04-01 10:38
246 查看
日期计算
时间限制:3000 ms | 内存限制:65535 KB难度:1
描述如题,输入一个日期,格式如:2010 10 24 ,判断这一天是这一年中的第几天。
输入第一行输入一个数N(0<N<=100),表示有N组测试数据。后面的N行输入多组输入数据,每行的输入数据都是一个按题目要求格式输入的日期。
输出每组输入数据的输出占一行,输出判断出的天数n
样例输入
3 2000 4 5 2001 5 4 2010 10 24
样例输出
96 124 297
代码:
#include<stdio.h>
bool isLeapYear(int year);
int monthJudge(int month);
int main()
{
int k;
scanf("%d",&k);
int data[k][3],i,j,days=0;
for(i=0;i<k;i++)
for(j=0;j<3;j++)
scanf("%d",&data[i][j]);
for(i=0;i<k;i++)
{
days+=data[i][2];
for(j=1;j<data[i][1];j++)
days+=monthJudge(j);
if(isLeapYear(data[i][0])&&data[i][1]>2)
days+=1;
printf("%d\n",days);
days=0;
}
return 0;
}
bool isLeapYear(int year)
{
if((year%4==0&&year%100!=0)||year%400==0)
return true;
else
return false;
}
int monthJudge(int month)
{
if(month==1||month==3||month==5||month==7||month==8||month==10||month==12)
return 31;
else if(month==2)
return 28;
else
return 30;
}