From 4db8023227b3900740b8be361c436ddadb1d0585 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期二, 14 一月 2025 08:42:06 +0800 Subject: [PATCH] Merge branch 'master' of http://120.76.84.145:10101/gitblit/r/java/qijisheng --- ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/RedPackegeSetController.java | 60 +++++++++++++++++++++++++++++++++++++++++++++--------------- 1 files changed, 45 insertions(+), 15 deletions(-) diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/RedPackegeSetController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/RedPackegeSetController.java index 5edc8ff..d70cbd1 100644 --- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/RedPackegeSetController.java +++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/RedPackegeSetController.java @@ -13,6 +13,9 @@ import javax.annotation.Resource; import java.math.BigDecimal; import java.time.LocalDateTime; +import java.util.Arrays; +import java.util.Collections; +import java.util.Comparator; import java.util.List; /** @@ -63,23 +66,11 @@ @PostMapping("/addRedPackegeSet") @Transactional(rollbackFor = Exception.class) public R<Void> addRedPackegeSet(@RequestBody RedPackegeSetDto redPackegeSets){ - redPackegeSetService.remove(null); List<RedPackegeSet> redPackegeSetList = redPackegeSets.getRedPackegeSets(); - for (int i = 0; i < redPackegeSetList.size(); i++) { - RedPackegeSet redPackegeSet = redPackegeSetList.get(i); - LocalDateTime startTime = redPackegeSet.getStartTime(); - LocalDateTime endTime = redPackegeSet.getEndTime(); - for (int j = 0; j < redPackegeSetList.size(); j++) { - RedPackegeSet redPackegeSet1 = redPackegeSetList.get(j); - LocalDateTime startTime1 = redPackegeSet1.getStartTime(); - LocalDateTime endTime1 = redPackegeSet1.getEndTime(); - if(i != j && ((startTime.isAfter(startTime1) && endTime.isBefore(endTime1)) - || (startTime.isBefore(startTime1) && endTime.isAfter(startTime1) && endTime.isBefore(endTime1)) - || (startTime.isAfter(startTime1) && startTime.isBefore(endTime1) && endTime.isAfter(endTime1)))){ - return R.fail("时间有重叠,请重新配置"); - } - } + if (hasOverlap(redPackegeSetList)) { + return R.fail("时间段存在重叠,请重新配置"); } + redPackegeSetService.remove(null); redPackegeSetService.saveBatch(redPackegeSetList); return R.ok(); } @@ -94,5 +85,44 @@ return R.ok(); } + public static boolean hasOverlap(List<RedPackegeSet> redPackegeSetList) { + // 首先根据startTime对列表进行排序 + Collections.sort(redPackegeSetList, Comparator.comparing(RedPackegeSet::getStartTime)); + + // 然后检查是否存在重叠 + for (int i = 0; i < redPackegeSetList.size() - 1; i++) { + RedPackegeSet current = redPackegeSetList.get(i); + RedPackegeSet next = redPackegeSetList.get(i + 1); + + // 如果当前时间段的结束时间晚于或等于下一个时间段的开始时间,则存在重叠 + if (current.getEndTime().isAfter(next.getStartTime()) || + current.getEndTime().isEqual(next.getStartTime())) { + return true; + } + } + + return false; + } + + public static void main(String[] args) { + // 示例数据 + RedPackegeSet redPackegeSet = new RedPackegeSet(); + redPackegeSet.setStartTime(LocalDateTime.of(2025, 1, 13, 0, 0)); + redPackegeSet.setEndTime(LocalDateTime.of(2025, 1, 14, 0, 0)); + + RedPackegeSet redPackegeSet2 = new RedPackegeSet(); + redPackegeSet2.setStartTime(LocalDateTime.of(2025, 1, 13, 0, 0)); + redPackegeSet2.setEndTime(LocalDateTime.of(2025, 1, 14, 0, 0)); + List<RedPackegeSet> redPackegeSetList = Arrays.asList( + redPackegeSet,redPackegeSet2 + ); + + boolean overlapExists = hasOverlap(redPackegeSetList); + System.out.println("是否存在重叠: " + overlapExists); + } + + + + } -- Gitblit v1.7.1