1847. 最近的房间

1847. 最近的房间


题目链接:1847. 最近的房间

代码如下:

cpp 复制代码
class Solution 
{
public:
	vector<int> closestRoom(vector<vector<int>>& rooms, vector<vector<int>>& queries)
	{
		sort(rooms.begin(), rooms.end(), [&](vector<int>& a, vector<int>& b)
			{
				return a[1] > b[1];
			});

		vector<int> query_ids(queries.size());
		iota(query_ids.begin(), query_ids.end(), 0);
		//按照minSize从大到小排序
		ranges::sort(query_ids, {}, [&](int i) { return -queries[i][1]; });

		vector<int> res(queries.size(), -1);
		set<int> room_ids;
		int j = 0;
		for (int i : query_ids)
		{
			int prefered_id = queries[i][0], minSize = queries[i][1];
			while (j < rooms.size() && rooms[j][1] >= minSize)
			{
				room_ids.insert(rooms[j][0]);
				j++;
			}

			int diff = INT_MAX;
			auto it = room_ids.lower_bound(prefered_id);
			if (it != room_ids.begin())
			{
				auto p = prev(it);
				diff = prefered_id - *p;	//左边的差
				res[i] = *p;
			}
			if (it != room_ids.end() && *it - prefered_id < diff) //右边的差更小
			{
				res[i] = *it;
			}
		}
		return res;
	}
};
相关推荐
仟濹22 分钟前
【算法打卡day35(2026-03-31 周二)】DFS专项训练2(今日算法:DFS & 记忆化搜索 & 回溯)
c++·算法·蓝桥杯·深度优先
liuyao_xianhui31 分钟前
优选算法_岛屿的最大面积_floodfill算法_C++
java·开发语言·数据结构·c++·算法·leetcode·链表
寻寻觅觅☆38 分钟前
东华OJ-基础题-33-数字之和(C++)
数据结构·c++·算法
xvhao201338 分钟前
C++freopen的用法
开发语言·c++
南境十里·墨染春水1 小时前
C++ 笔记 仿函数(函数对象)
开发语言·c++·笔记
快乐的划水a1 小时前
封装动态库并调用
c++
xvhao20131 小时前
P4084 [USACO17DEC] Barn Painting G 题解
数据结构·c++·算法·深度优先·动态规划
云栖梦泽1 小时前
Linux内核与驱动:5.并发与竞争
linux·c++
不想看见4042 小时前
在AI时代下,刷LeetCode题的价值与意义
开发语言·c++·qt
南境十里·墨染春水2 小时前
C++ 笔记 多重继承 菱形继承(面向对象)
开发语言·c++·笔记