码迷,mamicode.com
首页 > 其他好文 > 详细

前缀和

时间:2020-01-12 15:16:47      阅读:70      评论:0      收藏:0      [点我收藏+]

标签:inline   mat   math   数组   lin   场景   class   二维   前缀数组   

前缀和

一维:

构建前缀数组:

for(int i=1;i<=n;++i)
  a[i]+=a[i-1];

应用场景:

①求 \(a[1]~a[i]\)的累加和

ans=a[i];

②求\(a[i]~a[j](j>=i)\)的累加和

ans=a[j]-a[i-1];

二维:

构建前缀数组:

for(int i=1;i<=n;++i)
    for(int j=1;j<=m;++j)
        a[i][j]+=a[i-1][j]+a[i][j-1]-a[i-1][j-1];

应用场景:

\((x_1<=i<=x_2,y_1<=j<=y_2)\)范围内的\(c[i][j]\)之和

ans=a[x2][y2]+a[x1-1][y1-1]-a[x1-1][y2]-a[x2][y1-1];

前缀和

标签:inline   mat   math   数组   lin   场景   class   二维   前缀数组   

原文地址:https://www.cnblogs.com/CADCADCAD/p/12182660.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!