leet_code_ 436_寻找右区间

leet_code_ 436_寻找右区间

题目描述

给定一组区间,对于每一个区间 i,检查是否存在一个区间 j,它的起始点大于或等于区间 i 的终点,这可以称为 j 在 i 的“右侧”。

对于任何区间,你需要存储的满足条件的区间 j 的最小索引,这意味着区间 j 有最小的起始点可以使其成为“右侧”区间。如果区间 j 不存在,则将区间 i 存储为 -1。最后,你需要输出一个值为存储的区间值的数组。

注意:

你可以假设区间的终点总是大于它的起始点。
你可以假定这些区间都不具有相同的起始点。

示例1:
输入: [ [1,2] ]
输出: [-1]

解释:集合中只有一个区间,所以输出-1。
示例 2:
输入: [ [3,4], [2,3], [1,2] ]
输出: [-1, 0, 1]

解释:对于[3,4],没有满足条件的“右侧”区间。
对于[2,3],区间[3,4]具有最小的“右”起点;
对于[1,2],区间[2,3]具有最小的“右”起点。

题目分析:
1.直接方法:暴力法
依次遍历每一个数组,从剩余数组中符合条件的最接近的右区间,复杂度为O(n*n)
2.借用hash 记录下数组第一个元素与第二个元素的位置并进行排序。我们取出排序后数组的每个区间,并从剩下的区间中找到起点刚好大于选中区间起点的那个。怎么操作呢?例如说,我们选取了第 ii 个区间。为了找到满足要求的,我们不需要查找后面的那些区间。这是因为 intervalsintervals 已经按照起点顺序排序,而区间的终点总大于起点。因此,我们只在满足 i+1< j < ni+1<j<n 的 区间 jj 中进行查找。按照升序顺序找到的第一个区间即为所求区间,因为后面的区间起点一定会更大。

def findRightInterval( intervals):
        """
        :type intervals: List[List[int]]
        :rtype: List[int]
        """
		
        length = len(intervals)
        ans = [-1 for i in range(length)]
        if length < 2:
            return ans
        key = [i for i in range(length)]
        array1 = []
        array2 = []
        for i in range(length):
            array1.append(intervals[i][0])
            array2.append(intervals[i][1])
        dic_low = dict(zip(key, array1))
        dic_low = sorted(dic_low.items(), key=lambda x:x[1], reverse=False)
        print("dic_low:",dic_low)
        dic_high = dict(zip(key, array2))
        dic_high = sorted(dic_high.items(),key=lambda x:x[1], reverse=False)
        print("dic_high:",dic_high)
        turn1, turn2 = 0,0
        while turn2 < length:
            if  dic_low[turn2][1] < dic_high[turn1][1]:
                turn2 += 1
            else:
                ans[dic_high[turn1][0]] = dic_low[turn2][0]
                turn1 += 1
        return ans

*Coder driving!!! *

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值