三维前缀和 C++

三维前缀和是指在三维数组中,对于每个位置上的元素,计算该位置及其左上角所有元素的和。

如果我们用一个三维数组prefixSum[x][y][z]来表示三维前缀和,其中x、y和z分别表示三维数组的三个维度上的索引

三维区间求和,考验空间想象能力。
前缀和表达式:
s[i][j][k]=s[i][j][k−1]+s[i][j−1][k]+s[i−1][j][k]−s[i−1][j−1][k]−s[i−1][j][k−1]−s[i][j−1][k−1]+s[i−1][j−1][k−1]+f[i][j][k]

(x1,x2,y1,y2,z1,z2)的区间的和为:

s[x2][y2][z2]−s[x1−1][y2][z2]−s[x2][y1−1][z2]−s[x2][y2][z1−1] + s[x2][y1−1][z1−1] + s[x1−1][y2][z1−1] + s[x1−1][y1−1][z2]−s[x1−1][y1−1][z1−1]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值