今日力扣:3242. 设计相邻元素求和服务

python 复制代码
DIRS = ((-1, 0), (1, 0), (0, -1), (0, 1), (1, 1), (-1, 1), (-1, -1), (1, -1))

class NeighborSum:
    def __init__(self, grid: List[List[int]]):
        n = len(grid)
        s = [[0, 0] for _ in range(n * n)]
        for i, row in enumerate(grid):
            for j, v in enumerate(row):
                for k, (dx, dy) in enumerate(DIRS):
                    x, y = i + dx, j + dy
                    if 0 <= x < n and 0 <= y < n:
                        s[v][k // 4] += grid[x][y]
        self.s = s

    def adjacentSum(self, value: int) -> int:
        return self.s[value][0]

    def diagonalSum(self, value: int) -> int:
        return self.s[value][1]

作者:灵茶山艾府
链接:https://leetcode.cn/problems/design-neighbor-sum-service/solutions/2868968/jian-ji-xie-fa-pythonjavacgo-by-endlessc-ymcf/
来源:力扣(LeetCode)

用一个长为 8 的数组存放偏移向量,前 4 个表示上下左右四个方向,后 4 个表示斜向的四个方向。

用一个大小为 n

2

×2 的数组 s 预处理元素和,其中 sv0 为 adjacentSum(v) 的结果,sv1 为 diagonalSum(v) 的结果。这可以在初始化时,遍历 gridij 以及偏移向量,累加每个元素的相邻元素之和计算出来。

复杂度分析

时间复杂度:初始化 O(n

2

),其余 O(1),其中 n 为 grid 的行数和列数。

空间复杂度:初始化 O(n

2

),其余 O(1)。

如果有用,可以点赞评论一下,让我知道看我文章的是人。

相关推荐
菜菜的顾清寒3 分钟前
力扣HOT100(51) 动态规划-单词拆分
算法·leetcode·动态规划
风筝在晴天搁浅11 分钟前
剑指Offer LCR 143.子结构判断
算法
咖啡八杯21 分钟前
GoF设计模式——装饰模式
java·算法·设计模式·装饰器模式
装不满的克莱因瓶22 分钟前
实现矩阵的点积:从数学原理到 NumPy 实战
人工智能·线性代数·算法·机器学习·矩阵·numpy
HZ·湘怡22 分钟前
树 的定义 与 性质
算法·
梦想的颜色22 分钟前
Docker 入门指南:从零开始掌握容器化技术
运维·服务器·vscode·python·算法·docker·云原生
cpp_250125 分钟前
P10109 [GESP202312 六级] 工作沟通
数据结构·c++·算法·题解·洛谷·gesp六级
吴可可12325 分钟前
CAD二次开发中多段线定点分割技巧
算法
逻极27 分钟前
Redis 从入门到精通:缓存设计与实战
数据结构·redis·缓存·哨兵集群
ʚ希希ɞ ྀ29 分钟前
全排列 --- 回溯
算法·leetcode·深度优先