3909 - 活了多少天
话说,小A和小B天天干架,今天小A和小B又干架了,他们俩干架有点特别,他们说出自己知道的人的名字,看看他们谁活的时间长,而且要计算出谁活的天数长,可是小A和小B都不会算他们活了多少天,只知道他们出生日期和死亡日期,聪明的ACM的你能帮他们写个高大上的程序给他们算算么?
Input
输入数据有多组,每组输入有两行,每行有三个数字,依次是年月日,中间用空格隔开,第一行是出生日期,第二行是死亡日期,输入数据都在int 范围内, 而且他出生年份一定小于去世年份。
Output
输出数据占一行,输出出生日期到死亡日期的天数。
Examples
Input
1606 2 24 1657 1 14
Output
18587
Solution C
#include<stdio.h> int main() { //freopen("111.txt","r",stdin); //freopen("111out.txt","w",stdout); int a[13] = {0, 31, 28, 31,30,31,30,31,31,30,31,30, 31}; int year1, month1, day1, year2, month2, day2, i, sum; while(scanf("%d%d%d%d%d%d",&year1,&month1,&day1,&year2,&month2,&day2) != EOF) { sum = a[month1] - day1; for(i = month1 + 1; i <= 12; i++) { if(i == 2 && ((year1 % 4 == 0 && year1 % 100 != 0) || (year1 % 400 == 0))) { sum += 29; continue; } sum += a[i]; } for(i = year1 + 1; i < year2; i++) { if((i % 4 == 0 && i % 100 != 0) || i % 400 == 0) sum += 366; else sum += 365; } sum += day2; for(i = 0; i < month2; i++) { if(i == 2 && ((year2 % 4 == 0 && year2 % 100 != 0) || (year2 % 400 == 0))) { sum += 29; continue; } sum += a[i]; } printf("%d\n",sum); } return 0; }
Solution C++
#include<iostream> #include<stdio.h> #include<string.h> #include<algorithm> #include<queue> #include<math.h> #define M(i,n,m) for(int i = n;i < m;i ++) #define L(i,n,m) for(int i = n;i >= m;i --) #define N(n,m) memset(n,m,sizeof(n)); const int MAX = 10010; using namespace std; int aa[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31}; int is(int i) { if((i%4 == 0 && i % 100 != 0)||(i % 400 == 0)) return 1; return 0; } int main() { int a,b,c,x,y,z; while(~scanf("%d%d%d%d%d%d",&a,&b,&c,&x,&y,&z)) { int sum; sum = (x - a) * 365; for(int i = a; i < x; i ++) if(is(i)) ++ sum; int t = c; for(int i = 1; i < b; i ++) t += aa[i]; if(is(a) && b > 2) t ++; sum -= t; t = z; for(int i = 1; i < y; i ++) t += aa[i]; if(is(x) && y > 2) t ++; sum += t; printf("%d\n",sum); } return 0; }