leetcode-887-三维形体投影面积
题目描述:
在 N * N 的网格中,我们放置了一些与 x,y,z 三轴对齐的 1 * 1 * 1 立方体。
每个值 v = grid[i][j] 表示 v 个正方体叠放在单元格 (i, j) 上。
现在,我们查看这些立方体在 xy、yz 和 zx 平面上的投影。
投影就像影子,将三维形体映射到一个二维平面上。
在这里,从顶部、前面和侧面看立方体时,我们会看到“影子”。
返回所有三个投影的总面积。
示例 1:
输入:[[2]]
输出:5
示例 2:
输入:[[1,2],[3,4]]
输出:17
解释:
这里有该形体在三个轴对齐平面上的三个投影(“阴影部分”)。

示例 3:
输入:[[1,0],[0,2]]
输出:8
示例 4:
输入:[[1,1,1],[1,0,1],[1,1,1]]
输出:14
示例 5:
输入:[[2,2,2],[2,1,2],[2,2,2]]
输出:21
提示:
1 <= grid.length = grid[0].length <= 500 <= grid[i][j] <= 50
要完成的函数:
int projectionArea(vector<vector<int>>& grid)
说明:
1、这道题给定一个二维的vector,记为grid,grid[i][j]表示在网格坐标为(i,j)的点上有grid[i][j]个立方体,每个立方体为1*1*1的体积。
要求从上方看下来,从前面看过去,从侧面看过去,从这三个方向看过去得到的投影面积之和是多少。
2、这是一道初中的数学题目吧?只不过我们现在用程序来自动化地完成运算,需要抽象出统一的规则。
①从上面看下来,这个好办,grid这个二维vector中有多少个不为0的元素,从上方看下来的投影面积就是多少。
比如grid为[[1,2],[3,4]],图形如题目描述中所示,有四个不为0的元素,所以上方看下来的投影面积是4。
②从前面看过去,这个也不难,比如[[1,2],[3,4]],我们说第一行第一列的元素是1,第一行第二列的元素是2,那么第一行我们最终能看到的投影面积就是2了,也就是取个最大值。
第二行第一列的元素是3,第二行第二列的元素是4,那么第二行我们最终能看到的投影面积也就是4了,也是取个最大值。
所以从前面看过去的投影面积,就是每一行的元素最大值的和。
③同理,从侧面看过去,这时候我们要取每一列的最大值了,最后再把每一列的最大值相加,就是我们要的侧面投影面积。
所以,代码如下:(附详解)
int projectionArea(vector<vector<int>>& grid)
{
int hang=grid.size(),lie=grid[0].size(),shang=0,max1,qian=0,ce=0;
for(int i=0;i<hang;i++)//按行读取
{
max1=0;
for(int j=0;j<lie;j++)
{
if(grid[i][j])//如果这个元素不为0
shang++;//那么shang加1
max1=max(max1,grid[i][j]);//取每一行的最大值
}
qian+=max1;//把每一行的最大值相加,存储在qian里面
}
for(int j=0;j<lie;j++)//按列读取
{
max1=0;
for(int i=0;i<hang;i++)
{
max1=max(max1,grid[i][j]);//取每一列的最大值
}
ce+=max1;//把每一列的最大值相加,存储在ce里面
}
return shang+qian+ce;//最终返回三个投影面积相加的和
}
上述代码实测8ms,因为总提交次数不足,所以还没有击败的百分比。
leetcode-887-三维形体投影面积的更多相关文章
- [Swift]LeetCode883. 三维形体投影面积 | Projection Area of 3D Shapes
On a N * N grid, we place some 1 * 1 * 1 cubes that are axis-aligned with the x, y, and z axes. Each ...
- Leetcode883.Projection Area of 3D Shapes三维形体投影面积
在 N * N 的网格中,我们放置了一些与 x,y,z 三轴对齐的 1 * 1 * 1 立方体. 每个值 v = grid[i][j] 表示 v 个正方体叠放在单元格 (i, j) 上. 现在,我们查 ...
- leetcode 892. 三维形体的表面积
题目描述: 在 N * N 的网格上,我们放置一些 1 * 1 * 1 的立方体. 每个值 v = grid[i][j] 表示 v 个正方体叠放在单元格 (i, j) 上. 返回最终形体的表面积. ...
- [LeetCode] 883. Projection Area of 3D Shapes 三维物体的投影面积
On a N * N grid, we place some 1 * 1 * 1 cubes that are axis-aligned with the x, y, and z axes. Each ...
- leetcode签到 892. 三维形体的表面积
题目 三维形体的表面积 在 N * N 的网格上,我们放置一些 1 * 1 * 1 的立方体. 每个值 v = grid[i][j] 表示 v 个正方体叠放在对应单元格 (i, j) 上. 请你返回最 ...
- [Swift]LeetCode892. 三维形体的表面积 | Surface Area of 3D Shapes
On a N * N grid, we place some 1 * 1 * 1 cubes. Each value v = grid[i][j] represents a tower of v cu ...
- [LeetCode] 887. Super Egg Drop 超级鸡蛋掉落
You are given K eggs, and you have access to a building with N floors from 1 to N. Each egg is iden ...
- [LeetCode] 223. Rectangle Area 矩形面积
Find the total area covered by two rectilinearrectangles in a 2D plane. Each rectangle is defined by ...
- Leetcode892.Surface Area of 3D Shapes三维形体的表面积
在 N * N 的网格上,我们放置一些 1 * 1 * 1 的立方体. 每个值 v = grid[i][j] 表示 v 个正方体叠放在单元格 (i, j) 上. 返回结果形体的总表面积. 示例 1: ...
随机推荐
- 链表求和12 · Add Two Numbers
反向存储,从左往右加 [抄题]: 你有两个用链表代表的整数,其中每个节点包含一个数字.数字存储按照在原来整数中相反的顺序,使得第一个数字位于链表的开头.写出一个函数将两个整数相加,用链表形式返回和.给 ...
- linux 一个网卡配置多个IP
在Redhat系列(redhat,Fedora,Centos,Gentoo)中的实现方法如下: 1.单网卡绑定多IP在Redhat系列中的实现方法 假设需要绑定多IP的网卡是eth0,请在/etc/s ...
- Qt Read and Write Csv File
This page discusses various available options for working with csv documents in your Qt application. ...
- yii 关于如何改变默认访问的控制器(site)
以前Yii1学了个皮毛就没去管了,现在想重新捡起来Yii2.0.2却出来了,于是搭建好环境来学习. 安装好Yii2后第一个想到的问题就是修改默认的控制器了. 按照网上所说,终于在/vendor/yii ...
- ubuntu server静态IP和DNS服务器设置
Ubuntu的网络参数保存在文件 /etc/network/interfaces中, 默认设置使用dhcp,动态IP获取. 设置静态ip的方法如下: 1) 编辑 /etc/network/inte ...
- sqlserver2014新特性
1.SQL Server 2014新特性探秘(1)-内存数据库 在传统的数据库表中,由于磁盘的物理结构限制,表和索引的结构为B-Tree,这就使得该类索引在大并发的OLTP环境中显得非常乏力,虽然有很 ...
- Java Thread系列(五)synchronized
Java Thread系列(五)synchronized synchronized锁重入 关键字 synchronized 拥有锁重入的功能,也就是在使用 synchronized 时,当线程等到一个 ...
- ORACLE DBLINK 使用
CREATE PUBLIC DATABASE LINK MYDBLINK CONNECT TO RAMS IDENTIFIED BY RAMS USING '(DESCRIPTION =(ADDRES ...
- HDU 5117 Fluorescent (数学+状压DP)
题意:有 n 个灯,初始状态都是关闭,有m个开关,每个开关都控制若干个.问在m个开关按下与否的2^m的情况中,求每种情况下亮灯数量的立方和. 析:首先,如果直接做的话,时间复杂度无法接受,所以要对其进 ...
- Swift实现UIKit Dynamic动画
iOS7引入了UIKit Dynamics,可以帮助开发者开发出更接近真实世界的动画效果.之前,用户如果要做出这样的效果,需要话很多的时间在物理计算和Core Animation上.现在,所有的一切都 ...