如何解决如何计算最长的不间断日期序列
我知道如何计算最长的不间断序列看起来像
list = [0,1,0]
现在我正在尝试使用像这样的日期列表
date1 = datetime.date(2021,5,11)
date2 = datetime.date(2021,12)
date3 = datetime.date(2021,18)
date4 = datetime.date(2021,19)
date5 = datetime.date(2021,20)
date6 = datetime.date(2021,25)
date7 = datetime.date(2021,26)
date_list = [date1,date2,date3,date4,date5,date6,date7]
我正在寻找最长的连续天数。我试图将天数序列转换为类似于第一个列表的内容,1 表示仅 1 天的差异(不间断),0 表示超过一天的差异(中断),但到目前为止我无法想出解决方案全部。
解决方法
假设它已排序
longest_start_index = 0
longest_end_index = 0
current_start_index = 0
current_end_index = 0
curr_date = date_list[0]
while (current_end_index < len(date_list)):
next_date = date_list[current_end_index]
if (next_date-curr_date).days > 1:
# next day is more than 1 day away so reset start index
current_start_index = current_end_index
else:
if (current_end_index - current_start_index) > (longest_end_index - longest_start_index):
longest_start_index = current_start_index
longest_end_index = current_end_index
current_end_index = current_end_index + 1
curr_date = next_date
print(f'Longest continuous sequence is from {date_list[longest_start_index]} to {date_list[longest_end_index]}')
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。