leetcode892. 三维形体的表面积

在 N * N 的网格上,我们放置一些 1 * 1 * 1 的立方体。

每个值 v = grid[i][j] 表示 v 个正方体叠放在对应单元格 (i, j) 上。

请你返回最终形体的表面积。

示例 1:

输入:[[2]]
输出:10

示例 2:

输入:[[1,2],[3,4]]
输出:34

示例 3:

输入:[[1,0],[0,2]]
输出:16

示例 4:

输入:[[1,1,1],[1,0,1],[1,1,1]]
输出:32

示例 5:

输入:[[2,2,2],[2,1,2],[2,2,2]]
输出:46

提示:

  • 1 <= N <= 50
  • 0 <= grid[i][j] <= 50

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/surface-area-of-3d-shapes
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

完整代码

基本思想:
遍历二维数组,一个一个的计算,计算截至到当前单元格,三维形体的表面积

  • 计算二维数组的每一个位置立方体的表面积,这里要减去重叠部分的面积
  • 减去左面重叠部分的面积
  • 减去上面重叠部分的面积
class Solution {
public:
    int surfaceArea(vector<vector<int>>& grid) {
        int res = 0;
        for(int i = 0; i < grid.size(); ++i){
            for(int j = 0; j < grid[0].size(); ++j){
                if(grid[i][j] == 0)
                    continue;
                res += grid[i][j] * 6 - (grid[i][j] - 1) * 2;
                if(i > 0)//上面重叠的部分面积
                    res -= min(grid[i][j], grid[i - 1][j]) * 2;
                if(j > 0)//左面重叠的部分面积
                    res -= min(grid[i][j], grid[i][j - 1]) * 2;
                //cout << res << " ";
            }
            
        }
        return res;
    }
};
发布了306 篇原创文章 · 获赞 11 · 访问量 6万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览