高维前缀和(差分)(sosdp)

高维前缀和

  • 二维前缀和:s[i][j]=s[i1][j]+s[i][j1]+a[i][j]s[i1][j1]
  • 三位前缀和:s[i][j][k]=s[i1][j][k]+s[i][j1][k]+s[i][j][k1]s[i1][j1][k]s[i1][j][k1]s[i][j1][k1]+s[i1][j1][k1]

    设空间的维度为 k,则:
  • 时间复杂度:O(||×2k)
    另外一种求解方式:
  • 二维:
for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) a[i][j]+=a[i-1][j]; for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) a[i][j]+=a[i][j-1];
  • 三维:
for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) for(int k=1;k<=p;k++) a[i][j][k]+=a[i-1][j][k]; for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) for(int k=1;k<=p;k++) a[i][j][k]+=a[i][j-1][k]; for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) for(int k=1;k<=p;k++) a[i][j][k]+=a[i][j][k-1];

  • 时间复杂度:O(||×k)

高维差分

  • 二维差分
    在子矩阵((x1,y1)(x2,y2) 分别为子矩阵左上角和右下角下标)中加上一个数 k,先差分:s[x1][y+1]+=k,s[x2+1][y1]=k,s[x1][y2+1]=k,s[x2+1][y2+1]+=k,再取前缀和
  • 三维差分
二进制表示
000 s[x1][y1][z1]+=k
001 s[x1][y1][z2+1]=k
010 s[x1][y2+1][z1]=k
011 s[x1][y2+1][z2+1]+=k
100 s[x2+1][y1][z1]=k
101 s[x2+1][y1][z2+1]+=k
110 s[x2+1][y2+1][z1]+=k
111 s[x2+1][y2+1][z2+1]=k


__EOF__

本文作者acwing_zyy
本文链接https://www.cnblogs.com/zyyun/p/15553248.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   zyy2001  阅读(230)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示