今日力扣: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)。

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

相关推荐
少司府13 小时前
C++进阶:AVL树
开发语言·数据结构·c++·二叉树·avl树
珠海西格电力13 小时前
零碳园区的竞争力体现在哪些方面?
大数据·人工智能·算法·架构·能源
孬甭_13 小时前
从基础到优化:深入理解插入排序与希尔排序
数据结构·算法·排序算法
好家伙VCC13 小时前
Rust+Bioinfo:80ms极速SNP注释引擎
java·开发语言·算法·rust
啦哈拉哈13 小时前
【Python】知识点零碎学习7
python·学习·算法
宝贝儿好13 小时前
【NLP】第八章:项目实操案例:文本情感分析
人工智能·python·深度学习·算法·自然语言处理
如竟没有火炬13 小时前
恢复二叉搜索树
数据结构·数据库·python·leetcode·动态规划
如竟没有火炬13 小时前
整数拆分——动态规划
开发语言·数据结构·python·算法·leetcode·动态规划
叫我:松哥13 小时前
基于数据挖掘的旅游景点个性化推荐系统设计与实现,Apriori和FP-Growth算法挖掘景点之间的关联规则
人工智能·python·算法·数据挖掘·数据分析·beautifulsoup
KaMeidebaby14 小时前
卡梅德生物技术快报|噬菌体筛选:技术实操:宽谱大肠杆菌噬菌体筛选全流程与性能验证方案
前端·人工智能·算法·数据挖掘·数据分析