《算法笔记》学习笔记(4):日期处理

题目描述
有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天。

输入
有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD

输出
每组数据输出一行,即日期差值

样例输入
20130101
20130105
样例输出
5

思路
先检查输入的两个数据,不妨假设第一个小于第二个(不满足则交换)。
创建一个存放非闰年和闰年每个月的天数的二维数组,用基础运算(/和%)求出输入的日期中的年、月、日。
在计算时,现将天数+1,若其超出对应的月份的天数,则将天数置1,月份+1,同时若月份超出12,则将月份置1,年份+1,统计值+1。
值得注意的是,这里的统计值ans初值应设为1。

示例程序

#define _CRT_SECURE_NO_WARNINGS  1
#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);
}
int main()
{
	int time1, y1, m1, d1;
	int time2, y2, m2, d2;
	int ans = 1;
	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;
		//若日期1小于日期2
		while(y1<y2||m1<m2||d1<d2)
		{
			//先加一天
			d1++;
			//判断是否为最后一天,若是则将日期置1,月份+1
			if (d1 == (month[m1][isLeap(y1)] + 1))
			{
				m1++;
				d1 = 1;
			}
			//判断是否为最后一月,若是则将月份置1,年份+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、付费专栏及课程。

余额充值