题目和昨天的差不多,都是有关于矩阵的,这里我们采用动态规划的方法进行解决。
首先我们先保存所有的前缀和,之后我们需要知道一点
sumRegion(row1, col1, row2, col2) = dp[row2][col2] - dp[row2][col1 - 1] - dp[row1 - 1][col2] + dp[row1 - 1][col1 - 1]
但是为什么呐?我们看一下下面的图,黄色的减去两边橙色的加上一个红色的就是我们要求的,因为多间去了一个红色的。
def __init__(self, matrix: List[List[int]]):
if not matrix or not matrix[0]:pass
else:
row = len(matrix)
col = len(matrix[0])
self.dp = [[ 0 ] * (col + 1) for _ in range(row + 1)]
# 求行的前缀和
for i in range(1, row + 1):
for j in range(1 ,col + 1):
self.dp[i][j] = self.dp[i][j - 1] + matrix[i - 1][j - 1]
# 求列的前缀和
for j in range(1, col + 1):
for i in range(1, row + 1):
self.dp[i][j] += self.dp[i - 1][j]
# 上面可以直接简写成如下
"""
for i in range(1, row + 1):
for j in range(1, col + 1):
self.dp[i][j] = matrix[i - 1][j - 1] + self.dp[i - 1][j] + self.dp[i][j - 1] - self.dp[i-1][j-1]
"""
def sumRegion(self, row1: int, col1: int, row2: int, col2: int) -> int:
return self.dp[row2 + 1][col2 + 1] - self.dp[row1][col2 + 1] - self.dp[row2 + 1][col1] + self.dp[row1][col1]