leetcode 1074. 元素和为目标值的子矩阵数量(map+前缀和)

给出矩阵 matrix 和目标值 target,返回元素总和等于目标值的非空子矩阵的数量。

子矩阵 x1, y1, x2, y2 是满足 x1 <= x <= x2 且 y1 <= y <= y2 的所有单元 matrix[x][y] 的集合。

如果 (x1, y1, x2, y2) 和 (x1’, y1’, x2’, y2’) 两个子矩阵中部分坐标不同(如:x1 != x1’),那么这两个子矩阵也不同。

示例 1:

在这里插入图片描述

输入:matrix = [[0,1,0],[1,1,1],[0,1,0]], target = 0
输出:4
解释:四个只含 0 的 1x1 子矩阵。
示例 2:

输入:matrix = [[1,-1],[-1,1]], target = 0
输出:5
解释:两个 1x2 子矩阵,加上两个 2x1 子矩阵,再加上一个 2x2 子矩阵。
示例 3:

输入:matrix = [[904]], target = 0
输出:0

解题思路

遍历所有可以可选的上下边界[i,j]。

  1. 在上下界已经确定的情况下,维护前缀和数组cnt[i],代表第i列所有元素的累加和。
  2. 从第一列开始不断累加,累加到cur当中,cur代表上下界确定的情况下,累加起来的前n列
  3. 使用map记录下前n列累加和为k1的情况,当遍历到前n2列时,累加和为k2时,若满足k2-k1=target,即说明子矩阵[n,n2]的和为target。

代码

func numSubmatrixSumTarget(matrix [][]int, target int) (res int) {

	
	for i := 0; i < len(matrix); i++ {
        col := make([]int, len(matrix[0]))
		for j := i; j < len(matrix); j++ {
			for z := 0; z < len(matrix[0]); z++ {
				col[z] += matrix[j][z]
			}
			func() {
				m := make(map[int]int)
				m[0] = 1
				cur := 0
				for i := 0; i < len(matrix[0]); i++ {
					cur += col[i]
					i2, has := m[cur-target]
					if has {
						res += i2
					}
					m[cur]++
				}
			}()
		}
	}
	return

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值