java 区间重叠判断

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

方法一:

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;

}

 

转载于:https://www.cnblogs.com/fbw-gxy/p/10728998.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你需要判断两个不等式区间是否重叠,可以考虑以下几种方法: 1. 数学方法:将两个不等式区间表示成数学式子,然后通过数学计算来判断它们是否重叠。例如,对于区间 [a1, b1] 和 [a2, b2],如果 b1 < a2 或者 b2 < a1,则两个区间重叠,否则它们重叠。 2. 使用 Java 语言自带的方法:Java 中的 Interval 类可以表示一个区间,而 Range 类可以表示一个不等式区间。你可以使用 Range 类的 isOverlappedBy() 方法来判断两个区间是否重叠。例如: ```java Range range1 = Range.closed(1, 5); // 区间 [1, 5] Range range2 = Range.closedOpen(4, 8); // 区间 [4, 8) if (range1.isOverlappedBy(range2)) { System.out.println("两个区间重叠"); } else { System.out.println("两个区间重叠"); } ``` 在这个示例代码中,我们使用 Range 类的 closed() 和 closedOpen() 方法来创建两个区间,然后使用 isOverlappedBy() 方法来判断它们是否重叠。 3. 自己实现判断方法:如果你不想使用 Java 自带的类库,你也可以自己实现判断方法。例如,你可以将两个区间表示成两个数组 [a1, b1] 和 [a2, b2],然后通过比较它们的最大值和最小值来判断它们是否重叠。具体实现方法可以参考以下示例代码: ```java int[] range1 = {1, 5}; // 区间 [1, 5] int[] range2 = {4, 8}; // 区间 [4, 8) if (Math.max(range1[0], range2[0]) <= Math.min(range1[1], range2[1])) { System.out.println("两个区间重叠"); } else { System.out.println("两个区间重叠"); } ``` 在这个示例代码中,我们使用 Math 类的 max() 和 min() 方法来比较两个区间的最大值和最小值,从而判断它们是否重叠

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值