题目描述
有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天。
输入
有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD
输出
每组数据输出一行,即日期差值
样例输入
20130101
20130105
样例输出
5
晴神代码:
#include<cstdio> #include<algorithm> using namespace std; bool isleap(int year) { return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0); } int month[13][2] = { { 0,0 },{ 31,31 },{ 28,29 },{ 31,31 } ,{ 30,30 },{ 31,31 } ,{ 30,30 } ,{ 31,31 } ,{ 31,31 } ,{ 30,30 } ,{ 31,31 } ,{ 30,30 } ,{ 31,31 } }; int main() { int time1, y1, m1, d1; int time2, y2, m2, d2; while (scanf("%d%d", &time1, &time2) != EOF) { if (time1 > time2) swap(time1, time2); y1 = time1 / 10000, m1 = (time1 % 10000) / 100, d1 = time1 % 100; y2 = time2 / 10000, m2 = (time2 % 10000) / 100, d2 = time2 % 100; int ans = 1; while (y1<y2 || m1<m2 || d1<d2) { d1++; if (d1 == month[m1][isleap(y1)] + 1) { m1++; d1 = 1; } if (m1 == 13) { m1 = 1; y1++; } ans++; } printf("%d\n", ans); } return 0; }
另种思路:通过计算两个日期和某个日期(比如00010101)的差值,两个差值再相减。
#include <cstdio> #include<cmath> int mon[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 }; int calday(int y, int m, int d) { int days = 1; int year = 1, month = 1, day = 1; while (1) { if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) mon[2] = 29; else mon[2] = 28; //这句不能省,否则2月变不回29天 if (year == y && month == m && day == d)break; days++; day++; if (day == mon[month] + 1) { //这部分和晴神相同 day = 1; month++; } if (month == 13) { month = 1; year++; } } return days; } int main() { int y, m, d; while (scanf("%4d%2d%2d", &y, &m, &d) != EOF) { //用%md直接读取y,m,d. int days1, days2; days1 = calday(y, m, d); scanf("%4d%2d%2d", &y, &m, &d); days2 = calday(y, m, d); printf("%d\n",(int) fabs(days2 - days1)+ 1); //这里一定是计算绝对值后再加一,而且fabs返回的是double 型 } return 0; }