Leetcode 807. 保持城市天际线(学习一下求行列max值的求法即可)

核心思想:贪心,位置i,j上的建筑能够增加到的最大高度为当前行i上最高的建筑h1,和当前列j上最高的建筑h2去一个min即可,这样就可以不会影响边际线。

打卡代码

cpp 复制代码
class Solution {
public:
    int maxIncreaseKeepingSkyline(vector<vector<int>>& grid) {
        int n = grid[0].size();
        int N = 55;
        int res = 0;
        int col[N], row[N];
        // 求每一行的最大值
        for(int i = 0; i < n; i ++){
            int curmax = -1;
            for(int j = 0; j < n; j ++){
                if(grid[i][j] > curmax)
                    curmax = grid[i][j];
            }
            row[i] = curmax;
        } 
        // 求每一列的最大值
        for(int i = 0; i < n; i ++){
            int curmax = -1;
            for(int j = 0; j < n; j ++){
                if(grid[j][i] > curmax)
                    curmax = grid[j][i];
            }
            col[i] = curmax;
        }
        // 根据col和row索引出答案
        for(int i = 0; i < n; i ++){
            for(int j = 0; j < n; j ++){
                int t = 0;  // 当前位置需要增加的高度
                int curh = min(row[i], col[j]);
                // cout << curh << " ";
                t = curh - grid[i][j];
                res += t;
            }
        }
        return res;
    }
};

优化一下求解每行/列求最大值的代码:

cpp 复制代码
class Solution {
public:
    int maxIncreaseKeepingSkyline(vector<vector<int>>& grid) {
        int n = grid[0].size();
        int N = 55;
        int res = 0;
        vector<int> col(n), row(n);
        // 求每一行的最大值.求每一列的最大值
        for(int i = 0; i < n; i ++){
            for(int j = 0; j < n; j ++){
                row[i] = max(row[i], grid[i][j]);
                col[j] = max(col[j], grid[i][j]);
            }
        } 
        // 根据col和row索引出答案
        for(int i = 0; i < n; i ++){
            for(int j = 0; j < n; j ++){
                int t = 0;  // 当前位置需要增加的高度
                int curh = min(row[i], col[j]);
                t = curh - grid[i][j];
                res += t;
            }
        }
        return res;
    }
};
相关推荐
2301_800256112 分钟前
第九章:空间网络模型(空间网络查询、数据模型、Connected、with Recursive、pgRouting)
网络·数据库·算法·postgresql·oracle
逑之1 小时前
C语言笔记10:sizeof和strlen,指针与数组
c语言·笔记·算法
saoys1 小时前
Opencv 学习笔记:创建与原图等尺寸的空白图像
笔记·opencv·学习
求梦8201 小时前
【力扣hot100题】旋转图像(15)
算法·leetcode·职场和发展
C雨后彩虹5 小时前
任务最优调度
java·数据结构·算法·华为·面试
晓幂7 小时前
【2025】HECTF
笔记·学习·web安全
少林码僧7 小时前
2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法
人工智能·python·算法·机器学习·ai·数据挖掘
钱彬 (Qian Bin)7 小时前
项目实践15—全球证件智能识别系统(切换为Qwen3-VL-8B-Instruct图文多模态大模型)
人工智能·算法·机器学习·多模态·全球证件识别
慕云紫英8 小时前
基金申报的一点经验
学习·aigc
微露清风8 小时前
系统性学习C++-第十八讲-封装红黑树实现myset与mymap
java·c++·学习