zoukankan      html  css  js  c++  java
  • LeetCode——三维形体的表面积

    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;
        }
    
  • 相关阅读:
    setState 是异步吗?
    React优化点滴
    JS原型,作用域,this,闭包
    Webpack 模块化打包优化
    JS异步编程
    Web网络安全
    Http2.0和Http3.0
    Http协议基础
    Harris算子以及未来的规划...
    剑指offer 二维数组查找
  • 原文地址:https://www.cnblogs.com/xym4869/p/13206957.html
Copyright © 2011-2022 走看看