首页 > 其他 > 详细

[Algorithm] 前缀和

时间:2018-06-26 16:47:32      阅读:176      评论:0      收藏:0      [点我收藏+]

一维前缀和

主要用于在O(1)时间内找出A[i]+A[i+1]+...+A[j]的和

原理:

用sum[i]表示A[1]+A[2]+...+A[i],则sum[0] = 0, sum[1] = A[1], sum[2] = A[1]+A[2]; sum[3]=A[1]+A[2]+A[3];

则A[i]+A[i+1]+A[i+2]+...+A[j] = sum[j]-sum[i-1]

 

二维前缀和

对于一个矩阵,在O(1)时间内求出子矩阵A[x2-x1][y2-y1]的和。

原理:

用sum[i][j]表示子矩阵中A[i-1][j-1]的和。sum[0][0] = 0, sum[1][1] = A[1][1]+sum[0][1]+sum[1][0]-sum[0][0]

则,sum[i][j] = A[i][j]+sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]

[Algorithm] 前缀和

原文:https://www.cnblogs.com/immjc/p/9229728.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!