Q:在 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

A:
每个grid的所有面都加上,然后把相贴的部分删去就好。

    public int surfaceArea(int[][] grid) {
        int n = grid.length;
        int area = 0;
        for (int i = 0; i < n; i++) {
            for (int j = 0; j < n; j++) {
                int level = grid[i][j];
                if (level > 0) {
                    area += level * 4 + 2;
                    area -= i > 0 ? Math.min(level, grid[i - 1][j]) * 2 : 0;//横向相贴删去
                    area -= j > 0 ? Math.min(level, grid[i][j - 1]) * 2 : 0;//纵向相贴删去
                }
            }
        }
        return area;
    }

相关文章:

  • 2022-12-23
  • 2022-03-01
  • 2021-12-19
  • 2022-01-09
  • 2021-08-14
  • 2021-08-26
  • 2021-12-13
  • 2022-12-23
猜你喜欢
  • 2021-07-20
  • 2021-08-03
  • 2022-12-23
  • 2021-08-09
  • 2021-07-23
  • 2022-03-09
相关资源
相似解决方案