力扣(LeetCode)436. 寻找右区间(2023.03.10)
创始人
2024-06-01 14:11:13

给你一个区间数组 intervals ,其中 intervals[i] = [starti, endi] ,且每个 starti 都 不同 。

区间 i 的 右侧区间 可以记作区间 j ,并满足 startj >= endi ,且 startj 最小化 。

返回一个由每个区间 i 的 右侧区间 在 intervals 中对应下标组成的数组。如果某个区间 i 不存在对应的 右侧区间 ,则下标 i 处的值设为 -1 。

示例 1:

输入:intervals = [[1,2]]
输出:[-1]
解释:集合中只有一个区间,所以输出-1。

示例 2:

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

示例 3:

输入:intervals = [[1,4],[2,3],[3,4]]
输出:[-1,2,-1]
解释:对于区间 [1,4] 和 [3,4] ,没有满足条件的“右侧”区间。
对于 [2,3] ,区间 [3,4] 有最小的“右”起点。

提示:

1 <= intervals.length <= 2 * 104
intervals[i].length == 2
-106 <= starti <= endi <= 106
每个间隔的起点都 不相同

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/find-right-interval

方法一:二分查找

C++提交内容:

class Solution {
public:vector findRightInterval(vector>& intervals) {unordered_map starts_map;vector starts;for (int i = 0; i < intervals.size(); ++i) {starts_map[intervals[i][0]] = i;starts.push_back(intervals[i][0]);}sort(starts.begin(), starts.end());vector res;for (auto& interval : intervals) {int idx = higher_find(starts, interval[1]);res.push_back(idx == -1 ? -1 : starts_map[starts[idx]]);}return res;}int higher_find(vector& starts, int target) {if (target > starts[starts.size() - 1])return -1;int left = 0;int right = starts.size() - 1;while (left < right) {int mid = left + (right - left) / 2;if (starts[mid] >= target) {right = mid;} else {left = mid + 1;}}return left;}
};

相关内容

热门资讯

多彩课堂助成长 (来源:内蒙古日报)转自:内蒙古日报5月6日,包头市昆都仑区第一实验小学学生正在学习西点制作。近年来...
伊朗官员称目前该国石化产品供应... 转自:财联社【伊朗官员称目前该国石化产品供应充足】财联社5月7日电,伊朗议会经济委员会一名成员当地时...
俄谴责乌军袭击致5名平民死亡 转自:成都日报锦观俄谴责乌军袭击致5名平民死亡 俄罗斯外交部发言人扎哈罗娃6日谴责乌军袭击了克...
每年支持校企合作开设一批订单班 转自:成都日报锦观成都出台《工作方案》,开展“订单式”技能人才培养每年支持校企合作开设一批订单班 ...
人类与鸟类都需要这场奇特的相遇 转自:成都日报锦观人类与鸟类都需要这场奇特的相遇 北京生物多样性保护研究中心研究员、科普作家郭...