C++基础算法前缀和和差分篇

📟作者主页:慢热的陕西人

🌴专栏链接:C++算法

📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言

主要讲解了前缀和和差分算法

在这里插入图片描述

文章目录

    • Ⅳ. 前缀和 和 差分
      • Ⅵ .Ⅰ前缀和
      • Ⅳ. Ⅱ 差分

Ⅳ. 前缀和 和 差分

Ⅵ .Ⅰ前缀和

① 一维前缀和

​ 就是构建一个新的数组s,用来存储另一个数组的和前i个数组元素的和。用公式表达就是:
S [ i ] = a [ 0 ] + a [ 1 ] + . . . . a [ i ] S[i] = a[0]+a[1]+ .... a[i] S[i]=a[0]+a[1]+....a[i]
​ 这个结果我们用一次遍历就可以得到(我们的S只从1开始算起,为了方便后面的计算)

for(int i = 1; i < a.size(); ++i)
{s[i] = s[i - 1] + a[i];
}

具体的应用就是我们可以快速得到数组一个区间[l,r]内元素的和。
s [ l , r ] = s [ r ] = s [ l − 1 ] s[l, r] = s[r] = s[l - 1] s[l,r]=s[r]=s[l1]
对应题目:

B3645 数列前缀和 2 - 洛谷

②二维前缀和:

二维数组的前缀和就是相当于把一位数组的前缀和拓展成二维数组的前缀和。

那么我们计算s[i]的表达式为:
s [ i ] [ j ] = s [ i ] [ j − 1 ] + s [ i − 1 ] [ j ] − s [ i − 1 ] [ j − 1 ] + a [ i ] [ j ] s[i][j] = s[i][j - 1] + s[i - 1][j] - s[i - 1][j - 1] + a[i][j] s[i][j]=s[i][j1]+s[i1][j]s[i1][j1]+a[i][j]
那么我们计算一个子矩阵[[i,l],[j,r]]的公式为
s [ [ i , l ] [ j , r ] ] = s [ l ] [ r ] − s [ i − 1 ] [ r ] − s [ l ] [ j − 1 ] + s [ i − 1 ] [ j − 1 ] s[[i,l][j,r]] = s[l][r] - s[i - 1][r] - s[l][j - 1] + s[i - 1][j - 1] s[[i,l][j,r]]=s[l][r]s[i1][r]s[l][j1]+s[i1][j1]
代码:

#include<iostream>
#include<stdlib.h>
using namespace std;const int N = 1010;int a[N][N], s[N][N];int main()
{int n, m, q;int x1, x2, y1, y2;scanf("%d%d%d", &n, &m, & q);for(int i = 1; i <= n; ++i)for (int j = 1; j <= m; ++j)scanf("%d", &a[i][j]);//计算前缀和for (int i = 1; i <= n; ++i)for (int j = 1; j <= m; ++j)s[i][j] = s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1] + a[i][j];while (q--){scanf("%d%d%d%d", &x1, &y1, &x2, &y2);printf("%d",(s[x2][y2] - s[x1 - 1][y2] - s[x2][y1 - 1] + s[x1 - 1][y1 - 1]));}
}

Ⅳ. Ⅱ 差分

① 一维差分

首先我们明确一个原则**差分是前缀和的逆运算,首先我们构建一个数组b和一个数组a,那么我们将b数组的前缀和存储在a数组中,我们这时候称b数组就是a数组的差分**a就是b的前缀和。

不难发现差分有这样一个性质:

a[l, r]加上一个常数c等价于b[l] += cb[r + 1] -= c.

这个性质非常的重要因为我们可以将a数组中的一些O(N)的操作降为b数组中O(1)的操作;

如下例题:

在这里插入图片描述

代码:

#include<iostream>
#include<stdlib.h>
using namespace std;const int N = 1000010;int a[N], b[N];void insert(int l, int r, int c)
{b[l] += c;b[r + 1] -= c;
}int main()
{int n, m;scanf("%d%d", &n, &m);for (int i = 1; i <= n; i++) scanf("%d", &a[i]);//利用性质算出差分for (int i = 1; i <= n; i++) insert(i, i, a[i]);while (m--){int l, r, c;scanf("%d%d%d", &l, &r, &c);insert(l, r, c);}//通过b计算经过操作后产生的afor (int i = 1; i <= n; ++i) b[i] += b[i - 1];for (int i = 1; i <= n; ++i) printf("%d ", b[i]);return 0;
}

②二维差分(差分矩阵)

差分矩阵和上面的一维差分的思路差不多,首先我们构建一个矩阵b和一个矩阵a,那么我们将b矩阵的前缀和存储在a矩阵中,我们这时候称b矩阵就是a矩阵的差分a就是b的前缀和。

性质上也是类似的,但是略有不同:

a[[x1, x2],[y1,y2]]加上一个常数c等价于:
b [ x 1 , y 1 ] + = c b [ x 2 , y 1 ] − = c b [ x 1 , y 2 ] − = c b [ x 2 , y 2 ] + = c b[x1,y1] += c \\ b[x2, y1] -= c\\ b[x1, y2] -= c\\ b[x2, y2] += c b[x1,y1]+=cb[x2,y1]=cb[x1,y2]=cb[x2,y2]+=c
例题:

在这里插入图片描述

代码:

#include<iostream>
#include<stdlib.h>
using namespace std;const int N = 1010;int a[N][N], b[N][N];void insert(int x1, int y1, int x2, int y2, int c)
{b[x1][y1] += c;b[x2 + 1][y1] -= c;b[x1][y2  +1] -= c;b[x2 + 1][y2  +1] += c;
}int main()
{int n, m, q;scanf("%d%d%d", &n, &m, &q);for (int i = 1; i <= n; ++i)for (int j = 1; j <= m; ++j)scanf("%d", &a[i][j]);//利用性质构造差分for (int i = 1; i <= n; ++i)for (int j = 1; j <= m; ++j)insert(i, j, i, j, a[i][j]);while (q--){int x1, y1, x2, y2, c;scanf("%d%d%d%d%d", &x1, &y1, &x2, &y2, &c);insert(x1, y1, x2, y2, c);}//计算前缀和矩阵for (int i = 1; i <= n; ++i)for (int j = 1; j <= m; ++j)b[i][j] += b[i - 1][j] + b[i][j - 1] - b[i - 1][j - 1];cout << endl;for (int i = 1; i <= n; ++i){for (int j = 1; j <= m; ++j)printf("%d ", b[i][j]);cout << endl;}return 0;
}

到这本篇博客的内容就到此结束了。
如果觉得本篇博客内容对你有所帮助的话,可以点赞,收藏,顺便关注一下!
如果文章内容有错误,欢迎在评论区指正

在这里插入图片描述

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

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

相关文章

echarts_柱状图+漏斗图

目录 柱状图(bar)需求[1] 复制案例[2] 修改类目轴方向[3] 修改数据渲染方向[4] 修改坐标轴文本样式 漏斗图(funnel)漏斗图的形状 柱状图(bar) 需求 如上图&#xff0c;做一个横向柱状图&#xff0c;后端返回的数据是从小向大排列的数据&#xff0c;希望能够按照顺序进行展示。…

【Docker】详解docker安装及使用

详解docker安装及使用 1. 安装docker1.1 查看docker版本信息 2. Docker镜像操作3. Docker容器操作4.知识点总结4.1 docker镜像操作4.2 docker容器操作4.3 docker run启动过程 参见docker基础知识点详解 1. 安装docker 目前Docker只能支持64位系统。 ###关闭和禁止防火墙开机自…

pytorch+CRNN实现

最近接触了一个仪表盘识别的项目&#xff0c;简单调研以后发现可以用CRNN来做。但是手边缺少仪表盘数据集&#xff0c;就先用ICDAR2013试了一下。 结果遇到了一系列坑。为了不使读者和自己在以后的日子继续遭罪。我把正确的代码发到下面了。 1&#xff09;超参数请不要调整&am…

Android oom_adj 详细解读

源码基于&#xff1a;Android R 0. 前言 在博文《oom_adj 内存水位算法剖析》一文中详细的分析了lmkd 中针对 oom_adj 内存水位的计算、使用方法&#xff0c;在博文《oom_adj 更新原理(1)》、《oom_adj 更新原理(2)》中对Android 系统中 oom_adj 的更新原理进行了详细的剖析。…

Linux Shell脚本文件

文章目录 Linux Shell脚本文件vim编辑器vi的使用 认识Bash变量环境变量用户操作变量delcare与typeset 命令的别名与历史命名 正则表达式Shell ScriptsShell Scripts良好习惯第一个shell其他shell例子 - 来自鸟哥linux私房菜语法介绍shell 的调试 Linux Shell脚本文件 vim编辑器…

Centos 7 安装 Oracle 11G

Oracle 11G 安装教程 准备环境 p13390677_112040_Linux-x86-64_1of7.zipp13390677_112040_Linux-x86-64_2of7.zipCentos 7- rhel7-英文版的系统–不想换语言的执行(LANGen_US)– 传输 文件到服务器上 创建用户和组 [rootlocalhost ~]# groupadd oracle [rootlocalhost ~]…

20230715----重返学习-vue3新API-Vue3和Vue2对比-vue3语法-Vue3编码

day-113-one-hundred-and-thirteen-20230715-vue3新API-Vue3和Vue2对比-vue3语法-Vue3编码 vue3新API Vue 3 迁移指南 虚拟DOM 说明:看01视频。虚拟DOM是用于让vue核心代码脱离浏览器的限制&#xff0c;在微信小程序、手机端、canvas之类也有能使用vue语法的可能&#xff0…

Windows11 C盘瘦身

1.符号链接 将大文件夹移动到其他盘&#xff0c;创建成符号链接 2.修改Android Studio路径设置 1.SDK路径 2.Gradle路径 3.模拟器路径 设置环境变量 ANDROID_SDK_HOME

FLutter 开发中 fijkplayer设置屏幕常亮

FLutter 视频播放&#xff1a; 目前在做FLutter种的视频播放功能&#xff0c;遇到了视频播放的时候&#xff0c;屏幕突然黑屏了。网上找了很多&#xff0c;无论是设置在原生的Activity界面&#xff0c;添加如下代码&#xff0c; getWindow().addFlags(WindowManager.LayoutPara…

基于单片机的盲人导航智能拐杖老人防丢防摔倒发短息定位

功能介绍 以STM32单片机作为主控系统&#xff1b; OLED液晶当前实时距离&#xff0c;安全距离&#xff0c;当前经纬度信息&#xff1b;超声波检测小于设置的安全距离&#xff0c;蜂鸣器报警提示&#xff1a;低于安全距离&#xff01;超声波检测当前障碍物距离&#xff0c;GPS进…

虚幻引擎复习笔记

虚幻引擎 宏观了解 工具链&#xff1a;纹理&#xff0c;材质&#xff0c;模型&#xff0c;动画&#xff0c;粒子&#xff0c;地形&#xff0c;声音&#xff0c;光照&#xff0c;毛发&#xff0c;破碎逻辑编写&#xff1a;蓝图可视化脚本&#xff0c;虚幻CGamePlay框架 初次接…

python发送邮件yagmail库

yagmail库发送邮件简洁&#xff0c;代码量少 import yagmaildef send_yagmail(sender, send_password, addressee, hostsmtp.qq.com, port465):yag yagmail.SMTP(sender, send_password, host, port)img_url https://img2.baidu.com/it/u483398814,2966849709&fm253&…

基于单片机的智能空调系统的设计与实现

功能介绍 以51单片机作为主控系统&#xff1b;LCD1602液晶显示当前水温&#xff0c;定时提醒&#xff0c;水量变化DS18B20检测当前水体温度&#xff1b;水位传感器检测当前水位&#xff1b;继电器驱动加热片进行水温加热&#xff1b;定时提醒喝水&#xff0c;蜂鸣器报警&#x…

学习注解的使用模拟RequestMapping解析path

文章目录 前言一、代码部分总结 前言 注解在后端开发过程中提供了许多的便利&#xff0c;提高了代码简洁性和可读性&#xff0c;在应用程序中占据越来越重要的作用&#xff0c;很有学习的必要&#xff0c;接下来会通过代码来完成对类、方法、属性注解的解析。 一、代码部分 p…

LeetCode面试题02.07.链表相交

面试题02.07.链表相交 两种解题思路 面试题02.07.链表相交一、双指针二、哈希集合 一、双指针 这道题简单来说&#xff0c;就是求两个链表交点节点的指针 这里注意&#xff1a;交点不是数值相等&#xff0c;而是指针相等 为了方便举例&#xff0c;假设节点元素数值相等&…

用Python采用Modbus-Tcp的方式读取485电子水尺数据

README.TXT 2023/6/15 V1.0 实现了单个点位数据通信、数据解析、数据存储 2023/6/17 V2.0 实现了多个点位数据通信、数据解析、数据存储 2023/6/19 V2.1 完善log存储&#xff0c;仅保留近3天的log记录&#xff0c;避免不必要的存储&#xff1b;限制log大小&#xff0c;2MB。架…

数字原生时代,奥哲如何让企业都成为“原住民”?

22年前&#xff0c;美国教育学家马克‧普伦斯基&#xff08;Marc Prensky&#xff09;出版了《数字原生与数字移民》&#xff08;Digital Natives, Digital Immigrants&#xff09;一书&#xff0c;首次提出了“数字原住民”和“数字移民”两大概念&#xff0c;用来定义跨时代的…

法规发展与算法备案:预测未来的重要议题

随着科技的快速发展&#xff0c;算法逐渐成为各行各业的核心驱动力&#xff0c;尤其在互联网领域&#xff0c;算法更是被赋予了生命力&#xff0c;为人们提供了便利的同时&#xff0c;也引发了一系列问题。因此&#xff0c;未来法规发展对于算法备案的关注将变得尤为重要。本文…

05-Vue基础之Class 与 Style 绑定

个人名片&#xff1a; &#x1f60a;作者简介&#xff1a;一名大二在校生 &#x1f921; 个人主页&#xff1a;坠入暮云间x &#x1f43c;座右铭&#xff1a;懒惰受到的惩罚不仅仅是自己的失败&#xff0c;还有别人的成功。 &#x1f385;**学习目标: 坚持每一次的学习打卡 文章…

OpenCV如何实现图像截取

import cv2img cv2.imread("image/2.png", 1) roi cv2.selectROI(img,showCrosshairTrue,fromCenterFalse) xmin,ymin,w,h roi imgROI img[ymin:yminh,xmin:xminw].copy()cv2.imshow("demo",imgROI) cv2.waitKey(0) 代码的核心就是用到了OpenCV中的函数…