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;
    }
};
相关推荐
敲代码的嘎仔7 小时前
JavaWeb零基础学习Day4——Maven
java·开发语言·学习·算法·maven·javaweb·学习方法
遇印记7 小时前
网络运维学习笔记
数据结构·笔记·学习
四谎真好看7 小时前
Java 黑马程序员学习笔记(进阶篇20)
java·笔记·学习·学习笔记
聪明的笨猪猪7 小时前
hot 100 (1)—— 两数之和(哈希)
java·经验分享·算法·哈希算法
D.....l7 小时前
STM32学习(MCU控制)(GPIO)
stm32·嵌入式硬件·学习
_dindong7 小时前
牛客101:链表
数据结构·c++·笔记·学习·算法·链表
JJJJ_iii7 小时前
【机器学习06】神经网络的实现、训练与向量化
人工智能·笔记·深度学习·神经网络·学习·机器学习·线性回归
wuk9987 小时前
基于位置式PID算法调节PWM占空比实现电机转速控制
单片机·嵌入式硬件·算法
sakoba8 小时前
MySQL的json处理相关方法
android·学习·mysql·json
序属秋秋秋8 小时前
《Linux系统编程之入门基础》【Linux基础 理论+命令】(下)
linux·运维·服务器·学习·ubuntu·xshell·命令