题目链接:http://codeup.cn/problem.php?cid=100000578&pid=0
题目描述
有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天。
输入
有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD
输出
每组数据输出一行,即日期差值
样例输入
20130101
20130105
样例输出
5
代码
#include<stdio.h>
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 isLeep(int year) {
return ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0));
}
int main () {
int time1, y1, m1, d1;
int time2, y2, m2, d2;
while(scanf("%d%d", &time1, &time2) != EOF){
if(time1 > time2){
int temp = time1;
time1 = time2;
time2 = temp;
}
y1 = time1 / 10000, m1 = time1 % 10000 / 100, d1 = time1 % 100;
y2 = time2 / 10000, m2 = time2 % 10000 / 100, d2 = time2 % 100;
int ans = 1; //ans记录天数
while(y1 < y2 - 1){
if(isLeep(y1))
ans += 366; //为加快速度,先将年份缩短到差一年再进行日期的+1
else
ans += 365;
y1 ++;
}
while(y1 < y2 || m1 < m2 || d1 < d2) { //第一个日期没有达到第二个日期时循坏
d1 ++;
if(d1 == month[m1][isLeep(y1)] + 1){
m1++;
d1 = 1;
}
if(m1 == 13){
y1++;
m1 = 1;
}
ans++;
}
printf("%d\n", ans);
}
return 0;
}
附:
闰年366天, 平年365天
闰年分:
-
普通闰年:公历年份是4的倍数的,且不是100的倍数,为闰年。(如2004年就是闰年);
-
世纪闰年:公历年份是整百数的,必须是400的倍数才是世纪闰年(如1900年不是世纪闰年,2000年是世纪闰年);
月份:
一、三、五、七、八、十、十二月,是三十一天;
四、六、九、十一,是三十天;
二月平年是二十八天,闰年二十九天;