繁体   English   中英

检查一堆间隔是否重叠

[英]Checking whether a bunch of intervals are overlapping

我不知道要搜索什么...检查一堆间隔是否不重叠的一种好方法是什么?

一切顺利:

a, b = 0.2, 0.3
c, d = 0.4, 0.6
e, f = 0.9, 1.0

不好:

a, b = 0.2, 0.3
c, d = 0.25, 0.5

邪恶²:

a, b = 0.2, 0.3
c, d = 0.4, 0.6
e, f = 0.1, 0.8

按起始值对时间间隔进行排序(如果它们只是2元组,这是自动的),然后遍历列表,确保一个终止值始终小于(或取决于您的问题)起始值。下一个。

intervals = [(0.2, 0.3),
             (0.8, 1.0),
             (0.4, 0.6),
             (0.32, 0.38)]

intervals = sorted(intervals)
disjoint = all(intervals[i+1][0] > intervals[i][1] for i in range(len(intervals) - 1))

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM