1. 程式人生 > 其它 >LeetCode-807 保持城市天際線

LeetCode-807 保持城市天際線

來源:力扣(LeetCode)

連結:https://leetcode-cn.com/problems/max-increase-to-keep-city-skyline

題目描述

在二維陣列grid中,grid[i][j]代表位於某處的建築物的高度。 我們被允許增加任何數量(不同建築物的數量可能不同)的建築物的高度。 高度 0 也被認為是建築物。

最後,從新陣列的所有四個方向(即頂部,底部,左側和右側)觀看的“天際線”必須與原始陣列的天際線相同。 城市的天際線是從遠處觀看時,由所有建築物形成的矩形的外部輪廓。 請看下面的例子。

建築物高度可以增加的最大總和是多少?

例子:
輸入: grid = [[3,0,8,4],[2,4,5,7],[9,2,6,3],[0,3,1,0]]
輸出: 35
解釋:
The grid is:
[ [3, 0, 8, 4],
[2, 4, 5, 7],
[9, 2, 6, 3],
[0, 3, 1, 0] ]

從陣列豎直方向(即頂部,底部)看“天際線”是:[9, 4, 8, 7]
從水平水平方向(即左側,右側)看“天際線”是:[8, 7, 9, 3]

在不影響天際線的情況下對建築物進行增高後,新陣列如下:

gridNew = [ [8, 4, 8, 7],
[7, 4, 7, 7],
[9, 4, 8, 7],
[3, 3, 3, 3] ]

解題思路

個人認為這道題難度並達不到中等難度

城市建築物構成了m*n的一個矩陣,不改變城市天際線,就表示每行每列的最大值不能改變,每個建築物最大高度是行最大值和列最大值中的最小值。那麼經過一次遍歷找到行最大值和列最大值,再經過一次遍歷找到增加後的建築物高度和,減去增加前的高度和,此題得解。

原始碼展示

class Solution {
public:
    int maxIncreaseKeepingSkyline(vector<vector<int>>& grid) {
        vector<int> viMaxL, viMaxT;
        int iSum = 0;
        int iM = grid.size();
        int iN = grid[0].size();
        viMaxL.resize(iM, 0);
        viMaxT.resize(iN, 0);

        
for(int i = 0; i< iM; i++) { for(int j = 0; j<iN; j++) { if(grid[i][j] > viMaxL[i]) { viMaxL[i] = grid[i][j]; } if(grid[i][j] > viMaxT[j]) { viMaxT[j] = grid[i][j]; } iSum -= grid[i][j]; } } for(int i = 0; i< iM; i++) { for(int j = 0; j<iN; j++) { iSum += min(viMaxL[i], viMaxT[j]); } } return iSum; } };

執行結果