892三位形体表面积LeetCode

1题目描述

这道题关键难点在于读题,后续引用了大佬的题解示意图来显示
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

题解 -单块计算累加

分别计算每一块,只要高度大于0,底部和顶部就贡献两个面积,侧面积会与四周重叠,在这里,观察与四周的高度若是本身高度grid[i][j]小于周围块高度n_val的就为0,大于则为两者之差

class Solution:
    def surfaceArea(self, grid: List[List[int]]) -> int:
        result=0
        len_grid=len(grid)
        for i in range(len_grid):
            for j in range(len_grid):
                if grid[i][j]>0:
                    result+=2
                for n_i,n_j in[(i-1,j),(i+1,j),(i,j-1),(i,j+1)]:
                    if  0<=n_i<len_grid and 0<=n_j<len_grid:
                        n_val=grid[n_i][n_j]
                    else:
                        n_val=0
                    result+=max(grid[i][j]-n_val,0)
        return result

在这里插入图片描述

发布了314 篇原创文章 · 获赞 23 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/weixin_39289876/article/details/105088698