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!!! *