解题代码
#include<cstdio>
#include<algorithm>
using namespace std;
int days[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 } };
bool IsLeap(int year) {
return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0);
}
int main()
{
int former, later;
int y1, m1, d1, y2, m2, d2;
while (scanf("%d%d", &former, &later) != EOF) {
if (former > later) swap(former, later);
y1 = former / 10000; y2 = later / 10000;
m1 = former % 10000 / 100; m2 = later % 10000 / 100;
d1 = former % 100; d2 = later % 100;
int cnt = 1;
while (y1 != y2 || m1 != m2 || d1 != d2) {
d1++;
cnt++;
if (d1 == days[m1][IsLeap(y1)] + 1) {
d1 = 1;
m1++;
}
if (m1 == 13) {
m1 = 1;
y1++;
}
}
printf("%d\n", cnt);
}
return 0;
}
测试结果
问题整理
1.日期处理。
2.注意日期差值的累加方法,注意平年闰年。
3.一天一天的累加就好,不要使用跳跃年份的办法,容易出错,虽然我也不知道哪里出错了。。。都怪这个codeup破网站。