如何利用计算机计算天数,计算机如何计算两个日期之间的天数

这篇博客探讨了如何使用Python计算两个日期之间的天数。文章通过一个示例展示了从2017年2月1日至6月1日的天数,并详细解释了核心算法`daysBetweenDates()`和`nextDay()`。这两个函数分别用于累计日期和处理闰年及月份变化。作者还提到了判断闰年的方法,并提供了一个外部链接进一步了解闰年算法。
摘要由CSDN通过智能技术生成

计算机是如何计算两个日期之间的天数的,这个问题看起来好像很简单,但是仔细一想,好像还没那么简单,月与月之间天数不一样,平年和闰年也会影响天数。

举个例子:

2017年2月1日-2017年6月1日中间有多少天?那么计算机应该如何计算?如果是你的话你应该怎么去算呢?

一般人:

按照月份加 :28+31+30+31+1

笨一点的人:找一本日历,一天一天的数,虽然慢一点,但只要会数数肯定也可以数出来

第一种算法对人类来说确实是简单的,但是有前提,你知道每个月有几天,今年是否是闰年,这个计算包含两部分,整月数,非整月数,人类几乎口算就可以;但是如果计算机实现起来,其实会复杂的多,因为计算机只会做一些简单重复的劳动,而且速度非常快。

下图是我用python实现的一个简单版本,基本实现了此项需求

import math

def isLeapYear(year):

'''judge a year is leapyear'''

if math.fmod(year, 4) == 0 and math.fmod(year, 100) != 0:

return True

if math.fmod(year, 400) == 0:

return True

return False

def daysInMonth(month, isLeapYear):

assert month >= 1 and month <= 12

monthDays = (31,28,31,30,31,30,31,31,30,31,30,31)

day = monthDays[month-1]

if isLeapYear and month == 2:

day += 1

return day

def nextDay(year, month, day):

isleap = isLeapYear(year)

monthDay = daysInMonth(month, isleap)

if day < monthDay:

return year, month, day + 1

else:

if month == 12:

return year + 1, 1, 1

else:

return year, month + 1, 1

def daysBetweenDates(year1, month1, day1, year2, month2, day2):

days = 0

nextday = (year1, month1, day1)

while True:

nextday = nextDay(nextday[0], nextday[1], nextday[2])

days += 1

if nextday == (year2, month2, day2):

return days

return None

核心算法是daysBetweenDates()和nextDay(), daysBetweenDates()的思想是,从第一个日期开始数,一直数到第二个日期返回; nextDay()实现了数日期的正确性,内部屏蔽了闰年和月份对天数的影响。

什么是闰年这个很多人一直忽略的问题,以及它的算法为什么是这个样子,这里贴一个链接。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值