区间重叠判断算法

一、背景

    在一次业务开发中,发现有一种数据,每天都会有一个值,不论是否是节假日。由于这个值的变化频率比较低,导致会有连续的N个日期,值是相同的。于是,就想将这些值合并。比如原来的结构是二元组DATA(Value , Date),合并成三元组DATA(Value , BeginDate , EndDate)。

   合并完原始数据后,生成三元组DATA1,还要和已经存在的三元组DATA2合并。于是就产生一个需求,如何判断日期区间DATE1[BeginDate , EndDate]和DATE2[BeginDate , EndDate]是重叠的。

二、命题

   假设存在两个区间A[A1 , A2] , B[B1 , B2],如何判断区间A和B存在重叠,重叠的长度多少。

三、算法

    1、Begin = Max(A1 , B1) ;

    2、End = Min(A2 , B2) ;

    3、Len = End - Begin


如果Len >= 0,那么区间AB重叠,重叠部分为Len;否则不重叠。

  



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值