- 描述
- 如题,输入一个日期,格式如:2010 10 24 ,判断这一天是这一年中的第几天。
- 输入
- 第一行输入一个数N(0<N<=100),表示有N组测试数据。后面的N行输入多组输入数据,每行的输入数据都是一个按题目要求格式输入的日期。
- 输出
- 每组输入数据的输出占一行,输出判断出的天数n
- 样例输入
-
3 2000 4 5 2001 5 4 2010 10 24
样例输出
96 124 297
代码示例一:
#include<bits/stdc++.h> using namespace std; int main() { int y,m,d,n,i; cin>>n; while(n--) { cin>>y>>m>>d; i=m; if(m>1) {//1 3 5 7 8 10 12 2 4 6 9 11 for(i=2;i<=m;i++) { if(i==2||i==4||i==6||i==8||i==9||i==11)//这里加的都是上一个月的天数,因为当月还没过完呢是吧 { d+=31; } if(i==3) { if(y%400==0||(y%100!=0&&y%4==0)) { d+=29; } else { d+=28; } } if(i==5||i==7||i==10||i==12) { d+=30; } } } cout<<d; if(n) { cout<<endl; } } }
代码示例二:
#include<stdio.h> int main() { int a,b=0,c,y,m,d,fib; scanf("%d",&a); while(a--) { scanf("%d %d %d",&y,&m,&d); if(y%400==0||y%100!=0&&y%4==0) fib=29; else fib=28; for(c=1;c<=m;c++) switch(c-1)//注意这里c要先减一,加的都是上月的天数 { case 1: case 3: case 5: case 7: case 8: case 10:b+=31;break; case 2:b+=fib;break; case 4: case 6: case 9: case 11:b+=30;break; } b+=d; printf("%d\n",b); b=0; } return 0; }