首先要了解一个叫做前缀和的东西。
二维前缀和其实就是将普通前缀和加了一维。
也就是可以求一个矩阵内任意子矩阵元素和。
仿照一维前缀和,转移方程如下:
[sum_{i,j}=sum_{i-1,j}+sum_{i,j-1}-sum_{i-1,j-1}+a_{i,j}
]
这个转移方程嘛,主要是先通过容斥原理求出前面的和,然后再加上本身的和。
这样我们求一个左上角坐标为 (x_1,y_1),右下角坐标为 (x_2,y_2) 的坐标中子矩阵和就可以 (mathcal O(1)) 查询了,很容易得知查询 (sum_{x2,y2}-sum_{x1-1,y2}-sum_{x2,y1-1}+sum_{x1-1,y1-1}) 即可。
具体原理也是容斥原理qaq。
二维前缀和和前缀和一样用就好啦。