华为机试【3、区间交集】

3、标题:区间交集
【区间交集】给定一组闭区间,其中部分区间存在交集。任意两个给定区间的交集,称为公共区间(如:[1,2],[2,3]的公共区间为[2,2],[3,5],[3,6]的公共区间为
[3,5])。公共区间之间 若存在交集,则需要合并(如:[1,3],[3,5]区间存在交集[3,3],需合并为[1,5])。按升序排列 输出合并后的区间列表。
输入描述: 一组区间列表,区间数为 N: 0<=N<=1000;区间元素为 X: -10000<=X<=10000。
输出描述: 升序排列的合并区间列表
备注:
1、区间元素均为数字,不考虑字母、符号等异常输入。
2、单个区间认定为无公共区间。
示例:
输入
[[0, 3], [1, 3], [3, 5], [3, 6]]
输出
[[1, 5]]

def common_section_merge(arr):
    if len(arr) == 1:
        return arr[0]
    arr.sort(key=lambda x: x[0])  # 区间列表按区间开头从小到大排序
    comm_section = []  # 公共区间列表
    # 两两对比取出所有交集列表
    for i in range(len(arr) - 1):
        for j in range(i + 1, len(arr)):
            if arr[i][-1] >= arr[j][0]:  # 存在交集
                comm_section.append([arr[j][0], min(arr[i][-1], arr[j][-1])])
    if len(comm_section) == 1:
        return comm_section
    comm_section.sort(key=lambda x: x[0])
    l = len(comm_section)
    i = 0
    # 合并交集列表之间的公共区间
    while i <= l - 2:
        if comm_section[i][-1] >= comm_section[i + 1][0]:
            comm_section[i][-1] = max(comm_section[i][-1], comm_section[i + 1][-1])
            comm_section.pop(i + 1)
            l -= 1
        else:
            i += 1
    return comm_section


print(common_section_merge([[0, 3], [1, 3], [3, 5], [3, 6]]))
全部评论
我也来一个py版本的: def f(arr): sort_arr = sorted(arr, key=lambda x: x[0]) print(sort_arr) n = len(sort_arr) if n == 1: return [] res = [] for i in range(1, n): for j in range(0, i): if sort_arr[i][0] < sort_arr[j][1]: res.append([sort_arr[i][0], min(sort_arr[i][1], sort_arr[j][1])]) sort_res = sorted(res, key=lambda x: x[0]) merge_res = [] for l in sort_res: if not merge_res or l[0] > merge_res[-1][1]: merge_res.append(l) elif l[0] <= merge_res[-1][1]: merge_res[-1] = [merge_res[-1][0], max(merge_res[-1][1], l[1])] return merge_res print(f([[1, 3], [3, 6], [0, 3], [3, 5]]))
点赞 回复 分享
发布于 2024-07-14 15:09 辽宁

相关推荐

不愿透露姓名的神秘牛友
07-09 12:23
转人工😡
门口唉提是地铁杀:五次握手了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
06-12 17:46
门头沟学院 Java
运营你豪哥:来说重点: ​1.项目前置,时间倒序。​​ 2.​项目描述强化结果与量化效果(STAR原则里的R)。​​ ​3.个人技能精炼,明确掌握程度,突出核心。​​ ​4.增加强有力开头的个人总结部分。​​ 5.​优化教育背景(成绩排名)、合并奖项与活动。​​
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
07-07 12:25
门头沟学院 Java
程序员牛肉:你这个智邮公司做的就是那个乐山市税务系统的服务吗?
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-08 13:05
点赞 评论 收藏
分享
评论
2
6
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务