2025.12.11 力扣每日一题

3531.统计被覆盖的建筑

大神解法 很巧妙

cpp 复制代码
class Solution {
public:
    int countCoveredBuildings(int n, vector<vector<int>>& buildings) {
        //row_min[y]:第 y 行中,所有建筑的最小 x 坐标(代表这一行最左边的建筑);
        //row_max[y]:第 y 行中,所有建筑的最大 x 坐标(代表这一行最右边的建筑);
        //col_min[x]:第 x 列中,所有建筑的最小 y 坐标(代表这一列最上边的建筑);
        //col_max[x]:第 x 列中,所有建筑的最大 y 坐标(代表这一列最下边的建筑);
        //初始化时:row_min/col_min设为INT_MAX(方便后续取更小值),row_max/col_max默认初始为 0(题目中建筑坐标是正整数,不影响)。
        vector<int> row_min(n + 1, INT_MAX), row_max(n + 1);
        vector<int> col_min(n + 1, INT_MAX), col_max(n + 1);
        //遍历所有建筑,统计每一行的左右边界、每一列的上下边界。
        for (auto& p : buildings) {
            int x = p[0], y = p[1];
            row_min[y] = min(row_min[y], x);
            row_max[y] = max(row_max[y], x);
            col_min[x] = min(col_min[x], y);
            col_max[x] = max(col_max[x], y);
        }
        int ans = 0;
        for (auto& p : buildings) {
            int x = p[0], y = p[1];
            // 条件:在当前行的左右之间,且在当前列的上下之间
            //row_min[y] < x:当前建筑在行的左边界右边(左边有建筑);
            //x < row_max[y]:当前建筑在行的右边界左边(右边有建筑);
            //col_min[x] < y:当前建筑在列的上边界下边(上边有建筑);
            //y < col_max[x]:当前建筑在列的下边界上边(下边有建筑)。
            if (row_min[y] < x && x < row_max[y] && col_min[x] < y &&
                y < col_max[x]) {
                ans++;
            }
        }
        return ans;
    }
};
相关推荐
Yzzz-F35 分钟前
Problem - 2205D - Codeforces
算法
智者知已应修善业1 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn1 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室2 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星2 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿3 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨3 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月4 小时前
map与unordered_map区别
算法·哈希算法
qeen874 小时前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
图码4 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻