V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
code402
V2EX  ›  程序员

请教一个问题,如何在线段区间上进行快速拆分:所有数据都是升序放着。

  •  1
     
  •   code402 · 2020-10-10 08:47:01 +08:00 · 549 次点击
    这是一个创建于 1303 天前的主题,其中的信息可能已经有所发展或是发生改变。
    1.线段区间为[10,20],要切割的几个点为[1,1] [3,5] [9,11] [13,14] [19,30]
    移除区间[10,11] [13,14] [19,20]
    剩余区间[12,12] [15,18]

    2.线段区间为[10,20],要切割的几个点为 [21,30]
    剩余区间[10,20]

    我自己写的代码是根据两个区间的位置关系分了 9 种场景单独去写感觉有点麻烦,效率还特别低:
    whileFalse
        1
    whileFalse  
       2020-10-10 10:39:00 +08:00
    什么意思,举个实例吧。
    kikikiabc
        2
    kikikiabc  
       2020-10-10 23:37:13 +08:00
    换个说法:这个月你 10 号入职,今天是 20 号。其中,本月的 9-11 号、13-14 号,19-30 号都是公休或假期,请问你哪些天在上班?

    感觉就是个集合的减法问题

    def area(a, b): return set(list(range(a, b+1)))
    a = area(10, 20)
    b = area(13, 14)
    print('a', a)
    print('b', b)
    print('a-b', a-b)
    print(area(10, 20) - area(13, 14) - area(9, 11) - area(19, 30) - area(3, 4))
    依次,或者不依次,减就行了

    a {10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20}
    b {13, 14}
    a-b {10, 11, 12, 15, 16, 17, 18, 19, 20}
    {12, 15, 16, 17, 18}
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1124 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 17:51 · PVG 01:51 · LAX 10:51 · JFK 13:51
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.