日期计算
时间限制:
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<iostream>
- using namespace std;
- bool runnian(int);
- int dijitian(int,int,int);
- bool runnian(int a)
- {
- if(a%400 == 0 || (a%4==0 && a%100 != 0)) return 1;
- else return 0;
- }
- int dijitian(int a,int b,int c)
- {
- int sum=0;
- for(int i=1;i<b;i++)
- {
- if(i==1||i==3||i==5||i==7||i==8||i==10||i==12)
- sum+=31;
- if(i==4||i==6||i==9||i==11)
- sum+=30;
- if(i==2)
- {
- if(runnian(a)) sum+=29;
- else sum+=28;
- }
- }
- return sum+c;
- }
- int main()
- {
- int n;
- int a,b,c;
- cin>>n;
- while(n--)
- {
- cin>>a>>b>>c;
- cout<<dijitian(a,b,c)<<endl;
- }
- return 0;
- }