今日力扣: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 预处理元素和,其中 s[v][0] 为 adjacentSum(v) 的结果,s[v][1] 为 diagonalSum(v) 的结果。这可以在初始化时,遍历 grid[i][j] 以及偏移向量,累加每个元素的相邻元素之和计算出来。

复杂度分析

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

2

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

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

2

),其余 O(1)。

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

相关推荐
超梦dasgg16 小时前
并查集(Union-Find)详解 + Java 完整实现
java·数据结构·算法·图搜索
仍然.16 小时前
算法题目---队列+宽搜(BFS)
算法·宽度优先
AbandonForce17 小时前
从入门到入土:二分查找算法
数据结构·算法
L_090717 小时前
【C++】数据结构之哈希表(散列表)
数据结构·c++·散列表
仰泳之鹅17 小时前
【C语言】动态内存管理
c语言·数据结构·算法
心中有国也有家17 小时前
CANN 学习新范式:cann-learning-hub 如何让昇腾入门不再「劝退」
人工智能·经验分享·笔记·学习·算法
LB211217 小时前
C++通讯录课设(西安石油大学)
开发语言·c++·算法
AI算法沐枫17 小时前
机器学习知识点:正则化
人工智能·pytorch·python·深度学习·神经网络·算法·机器学习
手写码匠17 小时前
从零实现一个轻量级向量搜索引擎(Python 版)
人工智能·深度学习·算法·aigc
_Evan_Yao17 小时前
数据结构太难了?用画图的方式理解链表和栈和树和图
数据结构·学习·链表