首页 > 编程语言 > 详细

java 区间重叠判断

时间:2019-04-18 13:28:06      阅读:136      评论:0      收藏:0      [点我收藏+]

百度后看了一些解法,效率虽可能比较高,但相对代码太复杂,不便于阅读与代码交接,自己写了下,方法如下。

方法一:

private void checkOverlap(LinkedList<ActiveExtendDTO> activeExtendDOList) {
        activeExtendDOList.sort(Comparator.comparing(ActiveExtendDTO::getCommodityMinNum));
        Long temp = activeExtendDOList.poll().getCommodityMaxNum();
        for (ActiveExtendDTO activeExtend : activeExtendDOList) {
            if (temp >= activeExtend.getCommodityMinNum()) {
                throw new Exception("区间有重叠");
            }
            temp = activeExtend.getCommodityMaxNum();
        }
    }

方法二(1.8):

private void checkOverlap2(List<ActiveExtendDTO> list) {
        list.stream().sorted(Comparator.comparing(ActiveExtendDTO::getCommodityMinNum))
            .reduce((a, b) -> {
                if (a.getCommodityMaxNum() >= b.getCommodityMinNum()) {
                    throw new Exception("区间有重叠");
                }
                return b;
            });
    }

 

附ActiveExtendDTO类:

@Data
public class ActiveExtendDTO {

    @ApiModelProperty(value = "最小数量")
    @NotBlank(message = "最小数量不可为空")
    private Long commodityMinNum;

    @ApiModelProperty(value = "最大数量")
    @NotBlank(message = "最大数量不可为空")
    private Long commodityMaxNum;

}

 

java 区间重叠判断

原文:https://www.cnblogs.com/fbw-gxy/p/10728998.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!