日期处理

日期处理

日期处理每次思考时都会感觉很麻烦,因为我们必须处理好平年与闰年,大月与小月等细节的关系。我们列出解决该类问题的一个思路。

问题:
有两个日期,求这两个日期之间的天数。

样例输入:
20181225
20181226

样例输出:
1
思路:可以令较小的日期不断加一天直到等于较大的日期,利用Count计数即可。并且我们可以给定一个二维数组int month[13][2]存放每个月的天数,第二维0表示平年,1表示闰年。当然如果感觉这样太麻烦直接将较小日期的年份加到比较大年份小1即可,中间计算多少个平年与闰年

#include<cstdio>
#include<cmath>
#include<algorithm>
#include<iostream>
#include<cstring>
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 YN(int year)//判读是否为闰年 
{
	return (year%4==0&&year%100!=0)||(year%400==0);
} 
int main()
{
	int t1,t2;
	cin>>t1>>t2;
	if(t1>t2)
		swap(t1,t2);
	int y1,m1,d1;
	int y2,m2,d2;
	y1=t1/10000,m1=t1%10000/100,d1=t1%100;
	y2=t2/10000,m2=t2%10000/100,d2=t2%100;
	int ans=1;
	while(y1<y2||m1<m2||d1<d2)
	{
		d1++;
		if(d1==month[m1][YN(d1)]+1)
		{
			m1++;
			d1=1;
		}
		if(m1==13)
		{
			y1++;
			m1=1;
		}
		ans++;
	}
	cout<<ans;
	return 0;
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值