集合帖:前缀和及差分模板题 ← 一维及二维

news2025/1/21 17:26:44

【一维前缀和及一维差分知识点】
● 一维“前缀和数组”预处理过程:cin>>a[i], sum[i]=sum[i-1]+a[i]  或者  cin>>sum[i], sum[i]+=sum[i-1]   (1≤i≤n)
● 一维“区间和”计算过程:sum[y]-sum[x-1]      (y≥x)
● 长度为 k 的区间和的公式为:sum[i]-sum[i-k]
● 一维区间操作转端点操作 d[le]+=x,d[ri+1]-=x,可以高效地对区间 [le,ri] 内的每个元素都 +x。

(一)一维前缀和
题目来源:
https://www.acwing.com/problem/content/797/
代码来源:https://blog.csdn.net/hnjzsyjyj/article/details/144885387

#include <bits/stdc++.h>
using namespace std;
 
const int maxn=1e5+5;
int a[maxn],s[maxn];
 
int main() {
    int n,m;
    scanf("%d%d",&n,&m);
 
    for(int i=1; i<=n; i++) {
        scanf("%d",&a[i]);
        s[i]=s[i-1]+a[i];
    }
 
    while(m--) {
        int le,ri;
        scanf("%d%d",&le,&ri);
        printf("%d\n",s[ri]-s[le-1]);
    }
 
    return 0;
}
 
/*
in:
5 3
2 1 3 6 4
1 2
1 3
2 4

out:
3
6
10
*/

(二)一维差分
题目来源:https://www.acwing.com/problem/content/799/
代码来源:https://blog.csdn.net/hnjzsyjyj/article/details/139963345

#include <bits/stdc++.h>
using namespace std;
 
const int N=1e5+5;
int a[N]; //Primitive array
int d[N]; //Difference array
 
int main() {
    int n,m;
    cin>>n>>m;
    for(int i=1; i<=n; i++) { //i from 1
        cin>>a[i];
        d[i]=a[i]-a[i-1]; //Building a difference array
    }
 
    int le,ri,c;
    while(m--) {
        cin>>le>>ri>>c;
        d[le]+=c;
        d[ri+1]-=c;
    }
 
    for(int i=1; i<=n; i++) { //i from 1
        a[i]=d[i]+a[i-1];
        cout<<a[i]<<" ";
    }
 
    return 0;
}
 
/*
in:
6 3
1 2 2 1 2 1
1 3 1
3 5 1
1 6 1

out:
3 4 5 3 4 2
*/

【二维前缀和及二维差分知识点】
● 二维“前缀和数组”预处理过程:sum[i][j]=sum[i-1][j]+sum[i][j-1]-sum[i-1][j-1]+a[i][j]
● 二维“区间和”计算过程:( sum[x2][y2] - sum[x2][y1-1] ) - ( sum[x1-1][y2] - sum[x1-1][y1-1] ) = sum[x2][y2] - sum[x2][y1-1] - sum[x1-1][y2] + sum[x1-1][y1-1]       (y2≥y1,x2≥x1)
● 二维区间操作转端点操作
若二维区域的左上角坐标为 (x1, y1),右下角坐标为 (x2, y2),则如下代码可高效实现对此二维区域内所有元素 +x 的操作。

d[x1][y1]+=x;
d[x1][y2+1]-=x;
d[x2+1][y1]-=x;
d[x2+1][y2+1]+=x;


(一)二维前缀和
题目来源:
https://www.acwing.com/problem/content/798/
代码来源:https://blog.csdn.net/hnjzsyjyj/article/details/144908502

#include <bits/stdc++.h>
using namespace std;
 
const int maxn=1e3+5;
int a[maxn][maxn];
int s[maxn][maxn];
 
int main() {
    int n,m,q;
    cin>>n>>m>>q;
 
    for(int i=1; i<=n; i++)
        for(int j=1; j<=m; j++) {
            scanf("%d",&a[i][j]);
            s[i][j]=s[i][j-1]+s[i-1][j]-s[i-1][j-1]+a[i][j];
        }
 
    while(q--) {
        int x1,y1,x2,y2;
        scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
        printf("%d\n",s[x2][y2]-s[x2][y1-1]-s[x1-1][y2]+s[x1-1][y1-1]);
    }
 
    return 0;
}
 
/*
in:
3 4 3
1 7 2 4
3 6 2 8
2 1 2 3
1 1 2 2
2 1 3 4
1 3 3 4

out:
17
27
21
*/

(二)二维差分
题目来源:
https://www.acwing.com/problem/content/800/
代码来源:https://blog.csdn.net/hnjzsyjyj/article/details/139970246

#include <bits/stdc++.h>
using namespace std;

const int maxn=1e3+5;
int a[maxn][maxn];
int d[maxn][maxn];
int n,m,q;

int main() {
    cin>>n>>m>>q;
    for(int i=1; i<=n; i++) {
        for(int j=1; j<=m; j++) {
            cin>>a[i][j];
        }
    }

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

    while(q--) {
        int x1,y1,x2,y2,c;
        cin>>x1>>y1>>x2>>y2>>c;
        d[x1][y1]+=c;
        d[x1][y2+1]-=c;
        d[x2+1][y1]-=c;
        d[x2+1][y2+1]+=c;
    }

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

    for(int i=1; i<=n; i++) {
        for(int j=1; j<=m; j++) cout<<a[i][j]<<" ";
        cout<<endl;
    }

    return 0;
}

/*
in:
3 4 3
1 2 2 1
3 2 2 1
1 1 1 1
1 1 2 2 1
1 3 2 3 2
3 1 3 4 1

out:
2 3 4 1
4 3 4 1
2 2 2 2
*/



【一维前缀和及一维差分示例】  <--  洛谷 P5638:光骓者的荣耀
题目来源:https://www.luogu.com.cn/problem/P5638
代码来源:https://blog.csdn.net/hnjzsyjyj/article/details/145251582

#include <bits/stdc++.h>
using namespace std;
 
typedef long long LL;
const int maxn=1e6+5;
LL s[maxn],d[maxn];
LL t;
int n,k;
 
int main() {
    cin>>n>>k;
    for(int i=1; i<n; i++) {
        cin>>s[i];
        s[i]+=s[i-1];
    }
 
    for(int i=1; i<=n-k; i++) {
        t=max(t,s[i+k-1]-s[i-1]);
    }
    cout<<s[n-1]-t<<endl;
 
    return 0;
}
 
/*
in:
4 1
1 2 3

out:
3
*/

【二维前缀和及二维差分示例】  <--  洛谷 P3397:地毯
题目来源:https://www.luogu.com.cn/problem/P3397
代码来源:
https://blog.csdn.net/hnjzsyjyj/article/details/145268744

#include <bits/stdc++.h>
using namespace std;
 
const int maxn=1e3+5;
int a[maxn][maxn];
int d[maxn][maxn];
int n,m;
 
int main() {
    cin>>n>>m;
    while(m--) {
        int x1,y1,x2,y2;
        cin>>x1>>y1>>x2>>y2;
        for(int i=x1; i<=x2; i++) {
            d[i][y1]++;
            d[i][y2+1]--;
        }
    }
 
    for(int i=1; i<=n; i++) {
        for(int j=1; j<=n; j++) {
            a[i][j]=a[i][j-1]+d[i][j];
            cout<<a[i][j]<<" ";
        }
        cout<<endl;
    }
 
    return 0;
}
 
/*
in:
5 3
2 2 3 3
3 3 5 5
1 2 1 4

out:
0 1 1 1 0
0 1 1 0 0
0 1 2 1 1
0 0 1 1 1
0 0 1 1 1
*/




【参考文献】
https://blog.csdn.net/hnjzsyjyj/article/details/145251582
https://blog.csdn.net/hnjzsyjyj/article/details/145268744

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2279927.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux初识:【版本控制器Git】【调试器gdb/cgdb使用】

目录 一.版本控制器Git 1.1版本控制器 1.2Git的操作 1.2.1从远端仓库到本地 1.2.2工作区到本地暂存区 1.2.3本地暂存区到本地仓库 1.2.4本地仓库到远程仓库 1.2.5 .gitignore 1.2.6Windows上操作&#xff08;需要安装Tortoisegit&#xff09; 1.2.7同步远端和当地 二调…

【MATLAB源码-第259期】基于matlab的64QAM调制解调锁相环环载波同步仿真,对比前后星座图,输出锁相环响应曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 1. 概述 在现代数字通信系统中&#xff0c;为了提高频谱利用率和数据传输效率&#xff0c;经常采用多阶调制技术。64QAM&#xff08;64阶正交幅度调制&#xff09;便是其中的一种&#xff0c;它通过将数据映射到64个不同的复…

BEVFusion论文阅读

1. 简介 融合激光雷达和相机的信息已经变成了3D目标检测的一个标准&#xff0c;当前的方法依赖于激光雷达传感器的点云作为查询&#xff0c;以利用图像空间的特征。然而&#xff0c;人们发现&#xff0c;这种基本假设使得当前的融合框架无法在发生 LiDAR 故障时做出任何预测&a…

大模型LLM-微调 RAG

RAG小结 这篇文章是一篇关于大型语言模型&#xff08;LLMs&#xff09;增强技术的综述论文&#xff0c;特别聚焦于检索增强生成&#xff08;Retrieval-Augmented Generation, RAG&#xff09;这一领域。详细考察了RAG的发展、技术基础、关键技术、评估框架以及未来的研究方向。…

TongESB7.1.0.0如何使用dockercompose运行镜像(by lqw)

文章目录 安装准备安装 安装准备 1.安装好docker和dockercompose&#xff1a; docker、docker-compose安装教程&#xff0c;很详细 2.上传好安装相关文件 安装 使用以下命令导入管理端镜像和运行时镜像 docker load -i tongesb_manage_7100.tar docker load -i tongesb_se…

Acwing-基础算法课笔记之基础算法(二分)

Acwing-基础算法课笔记之基础算法&#xff08;二分&#xff09; 一、二分查找的概念1、使用二分的条件2、二分查找的算法流程 二、左闭右闭写法[left,right]三、左闭右开写法[left,right)四、浮点数的二分 一、二分查找的概念 1、使用二分的条件 1、必须是数组&#xff08;顺…

PHP教育系统小程序

&#x1f310; 教育系统&#xff1a;全方位学习新体验&#xff0c;引领未来教育风尚 &#x1f680; 教育系统&#xff1a;创新平台&#xff0c;智慧启航 &#x1f4f1; 教育系统&#xff0c;一款深度融合科技与教育的创新平台&#xff0c;匠心独运地采用先进的ThinkPHP框架与U…

蓝桥杯R格式--高精度算法模拟

#include <bits/stdc.h> using namespace std; int pos,p1; int ib[1566]; int an[1567]; int n; string a,b; int main() {cin>>n>>a;for(int ia.size()-1; i>0; i--){if(a[i]!.){pos;b.insert(b.end(),a[i]);///string 插char用insert/push_back} …

【电视盒子】HI3798MV300刷机教程笔记/备份遥控码修复遥控器/ADB/线刷卡刷/电视盒子安装第三方应用软件

心血来潮&#xff0c;看到电视机顶盒满天飞的广告&#xff0c;想改造一下家里的电视盒子&#xff0c;学一下网上的人刷机&#xff0c;但是一切都不知道怎么开始&#xff0c;虽然折腾了一天&#xff0c;以失败告终&#xff0c;还是做点刷机笔记。 0.我的机器 年少不会甄别&…

实战经验:使用 Python 的 PyPDF 进行 PDF 操作

文章目录 1. 为什么选择 PyPDF&#xff1f;2. 安装 PyPDF3. PDF 文件的合并与拆分3.1 合并 PDF 文件3.2 拆分 PDF 文件 4. 提取 PDF 文本5. 修改 PDF 元信息6. PDF 加密与解密6.1 加密 PDF6.2 解密 PDF 7. 页面旋转与裁剪7.1 旋转页面7.2 裁剪页面 8. 实战经验总结 PDF 是一种非…

C++11的多线程

目录 引言 thread类的简单介绍 接口解读 使用范例 move的作用--将资源“夺舍” 原子性操作库(atomic) lock_guard与unique_lock 前置知识&#xff1a;mutex锁&#xff08;类似linux下的ptrhead_mutex_t数据&#xff09; mutex的种类 1. std::mutex 2. std::recursive_…

电子应用设计方案96:智能AI充电器系统设计

智能 AI 充电器系统设计 一、引言 智能 AI 充电器系统旨在为各种电子设备提供高效、安全、智能的充电解决方案&#xff0c;通过融合人工智能技术&#xff0c;实现自适应充电、优化充电效率和保护电池寿命。 二、系统概述 1. 系统目标 - 自适应识别不同设备的充电需求&#xf…

logback日志自定义占位符

前言 在大型系统运维中&#xff0c;很大程度上是需要依赖日志的。在java大型web工程中&#xff0c;一般都会使用slf4jlogback这一个组合来实现日志的管理。 logback中很多现成的占位符可以可以直接使用&#xff0c;比如线程号【%t】、时间【%d】、日志等级【%p】&#xff0c;…

Stable Diffusion 3.5 模型在 Linux 上的部署指南

文章目录 前言-参考资料如下一. ComfyUI安装二.模型下载2.1 安装GGUF和T5 xxl编码模型2.2 安装ComfyUI辅助插件2.3 启动ComfyUI2.4 基础ComfyUI和SD3.5配置2.5 demo 前言-参考资料如下 ComfyUI WIKI教程 sd3.5 github 尝试过sd集成ollama&#xff0c;但是sd在ollama上无法良好…

【Go】Go数据类型详解—指针

1. 前言 在我看来&#xff0c;一门编程语言语法的核心就在于数据类型。而各类编程语言的基本数据类型大致相同&#xff1a;int整型、float浮点型、string字符串类型、bool布尔类型&#xff0c;但是在一些进阶数据类型上就有所不同了。本文将会介绍Go语言当中核心的数据类型——…

Grafana 统一可视化了,告警如何统一?

对于大部分公司&#xff0c;通常都不止一套监控、可观测性相关的系统&#xff0c;云上的、云下的&#xff0c;开源的、商业的&#xff0c;指标的、日志的、链路的&#xff0c;各个系统体验不同&#xff0c;权限难管&#xff0c;如何统一化并为各个团队赋能&#xff0c;是很多技…

LeetCode 110.平衡二叉树

题目描述 给定一个二叉树&#xff0c;判断它是否是平衡二叉树。 示例 1&#xff1a; 示例 2&#xff1a; 输入&#xff1a;root [1,2,2,3,3,null,null,4,4] 输出&#xff1a;false 示例 3&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;true 提示&#xff1a; …

【银河麒麟高级服务器操作系统】业务访问慢网卡丢包现象分析及处理过程

了解更多银河麒麟操作系统全新产品&#xff0c;请点击访问 麒麟软件产品专区&#xff1a;product.kylinos.cn 开发者专区&#xff1a;developer.kylinos.cn 文档中心&#xff1a;document.kylinos.cn 交流论坛&#xff1a;forum.kylinos.cn 服务器环境以及配置 【内核版本…

软件测试—— 接口测试(HTTP和HTTPS)

软件测试—— 接口测试&#xff08;HTTP和HTTPS&#xff09; HTTP请求方法GET特点使用场景URL结构URL组成部分URL编码总结 POST特点使用场景请求结构示例 请求标头和响应标头请求标头&#xff08;Request Headers&#xff09;示例请求标头 响应标头&#xff08;Response Header…

OpenCV相机标定与3D重建(60)用于立体校正的函数stereoRectify()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 为已校准的立体相机的每个头计算校正变换。 cv::stereoRectify 是 OpenCV 中用于立体校正的函数&#xff0c;它基于已知的相机参数和相对位置&am…