前缀和

前缀和

一维:

构建前缀数组:

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];
全部评论

相关推荐

11-26 22:34
已编辑
重庆邮电大学 Java
快手 客户端开发 (n+5)k*16 公积金12
牛客895077908号:佬 什么双非硕啊
点赞 评论 收藏
分享
10-17 12:16
同济大学 Java
7182oat:快快放弃了然后发给我,然后让我也泡他七天最后再拒掉,狠狠羞辱他一把😋
点赞 评论 收藏
分享
10-15 16:27
门头沟学院 C++
LeoMoon:建议问一下是不是你给他付钱😅😅
点赞 评论 收藏
分享
评论
点赞
1
分享
牛客网
牛客企业服务