让第一个小于第二个,如果不成立,交换
随后让第一个逐次加,直到加到第二个数据为止
#include <iostream>
#include <cstdio>
using namespace std;
int time1, time2;
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}
};
bool isLeap(int y){ // 判断是否是闰年
return y % 400 == 0 || (y % 4 == 0 && y % 100 != 0);
}
int main()
{
cin >> time1 >> time2;
if (time1 > time2){
int t = time1;
time1 = time2;
time2 = t;
}
int y1, m1, d1, y2, m2, d2;
y1 = time1 / 10000, m1 = time1 / 100 % 100, d1 = time1 % 100;
y2 = time2 / 10000, m2 = time2 / 100 % 100, d2 = time2 % 100;
int res = 1;
while (y1 < y2 || m1 < m2 || d1 < d2){
d1 ++;
if (d1 > month[m1][isLeap(y1)]){
d1 = 1;
m1 ++ ;
}
if (m1 > 12){
m1 = 1;
y1 ++ ;
}
res ++ ;
}
cout << res << endl;
return 0;
}