算法笔记 日期差值

在这里插入图片描述假设第一个日期早于第二个日期

#include<cstdio>
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); 		//1是闰年,0是平年 
}

int main()
{
	int time1,y1,m1,d1;
	int time2,y2,m2,d2;
	scanf("%d %d",&time1,&time2);
	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;   //记录结果 
	//第一个日期没有达到第二个日期时进行循环 即!((y1==y2)&&(m1==m2)&&(d1==d2)) =1时循环 
	while(y1<y2 || m1<m2 || d1<d2)		
	{
		d1++;			//天数+1
		if(d1==month[m1][isLeap(y1)]+1)				//满当月天数
		{				
			m1++;										//日期变为下个月的1号 
			d1=1; 
		} 
		if(m1==13)
		{
			y1++;
			m1=1;
		}
		ans++;
	} 
	printf("%d\n",ans);
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值