前缀和

前缀和

一维:

构建前缀数组:

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

相关推荐

程序员花海:1.技能放最后,来面试默认你都会,技能没啥用 2.实习写的看起来没啥含金量,多读读部门文档,包装下 接LLM这个没含金量 也不要用重构这种 不会给实习生做的 3.抽奖这个还是Demo项目,实际在公司里面要考虑策略,满减,触发点,触发规则 库存 之类的,不是这个项目这么简单 4.教育背景提前,格式为 教育背景 实习 项目 技能 自我评价
简历被挂麻了,求建议
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务