闻缺陷则喜何志丹

闻缺陷则喜何志丹

本文涉及的基础知识点

离线查询

LeetCode2250. 统计包含每个点的矩形数目

给你一个二维整数数组 rectangles ,其中 rectangles[i] = [li, hi] 表示第 i 个矩形长为 li 高为 hi 。给你一个二维整数数组 points ,其中 points[j] = [xj, yj] 是坐标为 (xj, yj) 的一个点。
第 i 个矩形的 左下角 在 (0, 0) 处,右上角 在 (li, hi) 。
请你返回一个整数数组 count ,长度为 points.length,其中 count[j]是 包含 第 j 个点的矩形数目。
如果 0 <= xj <= li 且 0 <= yj <= hi ,那么我们说第 i 个矩形包含第 j 个点。如果一个点刚好在矩形的 边上 ,这个点也被视为被矩形包含。
示例 1:
输入:rectangles = [[1,2],[2,3],[2,5]], points = [[2,1],[1,4]]
【C++离线查询】2250. 统计包含每个点的矩形数目-LMLPHP

输出:[2,1]
解释:
第一个矩形不包含任何点。
第二个矩形只包含一个点 (2, 1) 。
第三个矩形包含点 (2, 1) 和 (1, 4) 。
包含点 (2, 1) 的矩形数目为 2 。
包含点 (1, 4) 的矩形数目为 1 。
所以,我们返回 [2, 1] 。
示例 2:
输入:rectangles = [[1,1],[2,2],[3,3]], points = [[1,3],[1,1]]
【C++离线查询】2250. 统计包含每个点的矩形数目-LMLPHP

输出:[1,3]
解释:
第一个矩形只包含点 (1, 1) 。
第二个矩形只包含点 (1, 1) 。
第三个矩形包含点 (1, 3) 和 (1, 1) 。
包含点 (1, 3) 的矩形数目为 1 。
包含点 (1, 1) 的矩形数目为 3 。
所以,我们返回 [1, 3] 。
提示:
1 <= rectangles.length, points.length <= 5 * 10
rectangles[i].length == points[j].length == 2
1 <= li, xj <= 10
1 <= hi, yj <= 100
所有 rectangles 互不相同 。
所有 points 互不相同 。

C++二分查找

注意:y和高度<=100,故可以不用树状数组。
将rectangles按宽的降序排序
将points的下标indexs按x降序排序。
枚举indexs。
ys[j]记录矩形宽度大于等于points[i][0]且高度为j的矩形数量。
去掉排序的时间复杂度为:O(n100)

代码

核心代码

class Solution {
		public:
			vector<int> countRectangles(vector<vector<int>>& rectangles, vector<vector<int>>& points) {
				sort(rectangles.begin(), rectangles.end(), [&](const auto& v1, const auto& v2) {return v1[0] > v2[0]; });
				vector<int> indexs(points.size());
				iota(indexs.begin(), indexs.end(), 0);
				sort(indexs.begin(), indexs.end(), [&](int i1, int i2) {return points[i1][0] > points[i2][0]; });
				int ys[101] = { 0 };
				int j = 0;
				vector<int> ret;
				for (const auto& iiii : indexs) {
					while ((j < rectangles.size()) && (rectangles[j][0] >= points[iiii][0])) {
						ys[rectangles[j][1]]++;
						j++;
					}
					int cur = 0;
					for (int k = points[iiii][1]; k <= 100; k++) {
						cur += ys[k];
					}
					ret.emplace_back(cur);
				}
				return ret;
			}
		};

单元测试

vector<vector<int>>rectangles,  points;
		TEST_METHOD(TestMethod11)
		{
			rectangles = { {1,2},{2,3},{2,5} }, points = { {2,1},{1,4} };
			auto res = Solution().countRectangles(rectangles, points);
			AssertEx({ 2,1 }, res);
		}
		TEST_METHOD(TestMethod12)
		{
			rectangles = { {1,1},{2,2},{3,3} }, points = { {1,3},{1,1} };
			auto res = Solution().countRectangles(rectangles, points);
			AssertEx({1,3 }, res);
		}

【C++离线查询】2250. 统计包含每个点的矩形数目-LMLPHP

扩展阅读

视频课程

先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771
如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。

【C++离线查询】2250. 统计包含每个点的矩形数目-LMLPHP

08-27 18:50
查看更多