目录
【Codeup】1928: 日期差值
题目描述
有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天。
输入
有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD
输出
每组数据输出一行,即日期差值
样例输入
20130101
20130105
样例输出
5
思路:
直接的做法时让日期不断+1,直到第一个日期等于第二个日期为止,即可统计答案。
代码:
代码中的if 语句 if(d1==month[m1][isLeap(y1)]+1) 中的 +1 是为了判断日期是否达到了当前月份的最后一天。
单次测试:
#include<iostream>
using namespace std;
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 year){
return (year%4==0&&year%100!=0)||(year%400==0);
}
int main(){
int t1,t2;
int ant=1;
int y1,y2,m1,m2,d1,d2;
scanf("%d %d",&t1,&t2);
//默认t1为小日期
if(t1>t2){
int temp;
temp=t1;
t1=t2;
t2=temp;
}
//t1=20231015
y1=t1/10000; m1=t1%10000/100; d1=t1%100;
y2=t2/10000; m2=t2%10000/100; d2=t2%100;
//d1++
while(y1<y2||m1<m2||d1<d2){
d1++;
if(d1==month[m1][isLeap(y1)]+1){
//日期变为下一个月的一号
m1++;
d1=1;
}
//月数大于12时
if(m1==13){
y1++;
m1=1;
}
ant++;
}
printf("%d",ant);
return 0;
}
多次测试:
#include<iostream>
using namespace std;
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 year){
return (year%4==0&&year%100!=0)||(year%400==0);
}
int main(){
int t1,t2;
int y1,y2,m1,m2,d1,d2;
while(scanf("%d %d",&t1,&t2)!=EOF){
//默认t1为小日期
if(t1>t2){
int temp;
temp=t1;
t1=t2;
t2=temp;
}
//t1=20231015
y1=t1/10000; m1=t1%10000/100; d1=t1%100;
y2=t2/10000; m2=t2%10000/100; d2=t2%100;
int ans=1;
//d1++
while(y1<y2||m1<m2||d1<d2){
d1++;
if(d1==month[m1][isLeap(y1)]+1){
//日期变为下一个月的一号
m1++;
d1=1;
}
//月数大于12时
if(m1==13){
y1++;
m1=1;
}
ans++;
}
printf("%d\n",ans);
}
return 0;
}