LeetCode 3070. Count Submatrices with Top-Left Element and Sum Less Than k
周賽387。
題目
輸入整數矩陣 matrix 和整數 k。
求包含 grid 左上角元素的子矩陣中,有幾個子矩陣的總和小於等於 k。
解法
若要包含 grid 的左上角元素,則子矩陣的左上角座標必為 (0, 0)。
依照由左到右、由上到下的方向枚舉子矩陣的右下角,其實就是二維前綴和。
相似題 304. range sum query 2d immutable。
矩陣中不包含負數,因此若某右下角座標為 (r, c) 子矩陣,其總和超過 k,則 (r+1, c) 和 (r, c+1) 必定也不合法。
此作為一個小小的加速點,可以剪枝節省時間。
時間複雜度 O(MN)。
空間複雜度 O(MN)。
class Solution:
def countSubmatrices(self, grid: List[List[int]], k: int) -> int:
M, N = len(grid), len(grid[0])
ps = [[0] * (N + 1) for _ in range(M + 1)]
ans = 0
for r in range(M):
for c in range(N):
ps[r+1][c+1] = ps[r+1][c] + ps[r][c+1] - ps[r][c] + grid[r][c]
if ps[r+1][c+1] <= k:
ans += 1
else:
break
return ans
在計算二維前綴和的同時就可以計算答案,而且都只是以 (0, 0) 為左上角,不需要扣除其他前綴和,因此只需要保留上一列的以及左方格子的前綴和即可。
時間複雜度 O(MN)。
空間複雜度 O(N)。
class Solution:
def countSubmatrices(self, grid: List[List[int]], k: int) -> int:
M, N = len(grid), len(grid[0])
ps_col = [0] * N
ans = 0
for r in range(M):
ps = 0
for c in range(N):
ps += grid[r][c]
ps_col[c] += ps
if ps_col[c] <= k:
ans += 1
else:
break
return ans