【算法通关指南:算法基础篇】二维差分专题:1.【模板】差分 2.地毯

【算法通关指南:算法基础篇】二维差分专题:1.【模板】差分 2.地毯
在这里插入图片描述
🔥小龙报:个人主页
🎬作者简介:C++研发,嵌入式,机器人方向学习者
❄️个人专栏:《算法通关指南》
永远相信美好的事情即将发生
在这里插入图片描述


文章目录

前言

本专栏聚焦算法题实战,系统讲解算法模块:以《c++编程》,《数据结构和算法》《基础算法》《算法实战》 等几个板块以题带点,讲解思路与代码实现,帮助大家快速提升代码能力
ps:本章节题目分两部分,比较基础笔者只附上代码供大家参考,其他的笔者会附上自己的思考和讲解,希望和大家一起努力见证自己的算法成长

一、二维差分

可以类比「⼀维差分数组」的性质,推导出「⼆维差分矩阵」的性质:
• 在差分数组中某个位置标记:表示后续元素统⼀被修改;
• 在差分数组中求前缀和:能够还原出原始数组。
假设我们需要将原始矩阵a中,以(x1,y1)为左上角,(x2,y2)为右下角的子矩阵的每个元素都加上k

在这里插入图片描述


结论
由此可得差分矩阵的性质:
f[x1 ][y1 ]+ = k
f[x1 ][y2 + 1]− = k
f[x2 + 1][y1 ]− = k
f[x2 + 1][y2 + 1]+ = k

二、二维差分经典算法题

2.1【模板】差分

2.1.1题目

链接:【模板】差分

在这里插入图片描述

2.1.2 算法原理

依照刚才讲解二维差分原理模拟即可

2.2.3代码

#include<iostream> using namespace std;typedeflonglong LL;constint N =1100; LL f[N][N];voidcacl(LL x1, LL y1, LL x2, LL y2,LL k){ f[x1][y1]+= k; f[x1][y2 +1]-= k; f[x2 +1][y1]-= k; f[x2 +1][y2 +1]+= k;}intmain(){int n, m, q; cin >> n >> m >> q;for(int i =1; i <= n; i++){for(int j =1; j <= m; j++){ LL x; cin >> x;// [i, j]为左上⻆,[i, j]为右下⻆的矩阵,统⼀加上 x cacl(i, j, i, j, x);}}while(q--){ LL x1, y1, x2, y2,k; cin >> x1 >> y1 >> x2 >> y2 >> k;cacl(x1, y1,x2, y2, k);}for(int i =1; i <= n; i++){for(int j =1; j <= m; j++) f[i][j]+= f[i -1][j]+ f[i][j -1]- f[i -1][j -1];}for(int i =1; i <= n; i++){for(int j =1; j <= m; j++) cout << f[i][j]<<" "; cout << endl;}return0;}

2.2 地毯

2.2.1题目

链接:地毯

在这里插入图片描述

2.2.2 算法原理

直接利⽤二维差分矩阵模拟即可

2.2.3代码

#include<iostream> using namespace std;constint N =1010;int a[N][N];// 差分矩阵 voidcacl(int x1,int y1,int x2,int y2){ a[x1][y1]++; a[x1][y2 +1]--; a[x2 +1][y1]--; a[x2 +1][y2 +1]++;}intmain(){int n, m; cin >> n >> m;while(m--){int x1, y1, x2, y2; cin >> x1 >> y1 >> x2 >> y2;cacl(x1, y1, x2, y2);}for(int i =1; i <= n; i++){for(int j =1; j <= n; j++) a[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 <= n; j++) cout << a[i][j]<<" "; cout << endl;}return0;}

总结与每日励志

本文介绍了二维差分算法的原理和应用。二维差分通过在特定位置标记增量,可以高效处理子矩阵元素的批量修改。文章通过两道经典算法题(模板差分和地毯问题)展示了二维差分的实现方法,提供了完整的代码示例。核心思想是利用差分矩阵的性质,通过前缀和还原原始数组。算法简洁高效,适用于大规模矩阵操作。作者鼓励读者坚持学习,相信付出终有回报。

在这里插入图片描述

Read more

数据结构:⼆叉树(1)

数据结构:⼆叉树(1)

目录 前言  树部分知识: 一.树的概念和结构 二.树的一些相关术语和定义  三.树的实现结构(了解部分) 四、树的应用场景 二叉树部分知识讲解: 一.二叉树概念与结构 二.特殊二叉树类型 1.满二叉树 2.完全二叉树 3.性质补充 三、⼆叉树存储结构 顺序结构: 编辑应用: 链式结构: 四、堆的概念与结构 1.实现顺序结构⼆叉树: 2.堆的概念与结构 (重点) 3.堆的实现 五、堆的实现代码部分 1.堆的初始化:(本次实现选取大堆为例) 2.堆的销毁: 3.堆的插入数据 : 4.堆打印值 : 六、

By Ne0inhk

算法应用:2025年算法人工旅鼠算法(ALA)无人机路径规划研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭:行百里者,半于九十。 📋📋📋本文内容如下:🎁🎁🎁  ⛳️赠与读者 👨‍💻做科研,涉及到一个深在的思想系统,需要科研者逻辑缜密,踏实认真,但是不能只是努力,很多时候借力比努力更重要,然后还要有仰望星空的创新点和启发点。建议读者按目录次序逐一浏览,免得骤然跌入幽暗的迷宫找不到来时的路,它不足为你揭示全部问题的答案,但若能解答你胸中升起的一朵朵疑云,也未尝不会酿成晚霞斑斓的别一番景致,万一它给你带来了一场精神世界的苦雨,那就借机洗刷一下原来存放在那儿的“躺平”上的尘埃吧。      或许,雨过云收,神驰的天地更清朗.......🔎🔎🔎 💥第一部分——内容介绍 基于人工旅鼠算法(ALA)的无人机三维路径规划研究 摘要:随着无人机在复杂环境中的广泛应用,三维路径规划成为保障其安全高效执行任务的关键技术。传统算法在处理高维非线性约束问题时存在收敛速度慢、易陷入局部最优等缺陷。本文提出

By Ne0inhk
【C语言】排序算法——希尔排序以及插入排序 ——详解!!!

【C语言】排序算法——希尔排序以及插入排序 ——详解!!!

【C语言】排序算法——希尔排序以及插入排序详解 * 前言 * 一 、插入排序 * 1. 视频演示 * 2. 算法思想 * 3. 实现思路 * 4. 代码演示 * 二 、希尔排序 * 1. 视频演示 * 2. 算法思想 * 3. 实现思路 * (1)分组 * (2)预排序 * (3)最终排序 * (4)gap的取值 * 4. 代码演示 * 结语 前言 在学习循环的时候,我们学习到了冒泡排序这个算法 那么,除了冒泡排序,还有什么排序算法呢? 今天给大家带来的是插入排序以及希尔排序 一 、插入排序 1. 视频演示 首先给大家看一段视频,让大家先看看插入排序是怎么运行的 插入排序演示 2. 算法思想 我们可以从视频里看见,

By Ne0inhk
C语言指针与数组的深度关联及实战应用

C语言指针与数组的深度关联及实战应用

C语言指针与数组的深度关联及实战应用 💡 学习目标:掌握指针与数组的内在联系,熟练运用指针操作数组元素,解决实际开发中的数组遍历、数据交换等问题;学习重点:数组名的本质、指针算术运算操作数组、指针数组与数组指针的区别及应用。 38.1 数组名与指针的关系 在C语言中,数组和指针有着密不可分的联系。很多初学者会混淆数组名和指针变量的概念,其实二者既有关联,又有本质区别。 38.1.1 数组名的本质 💡 数组名在大多数情况下会被编译器隐式转换为指向数组首元素的常量指针。 我们来看一段简单的代码: #include<stdio.h>intmain(){int arr[5]={10,20,30,40,50};printf("数组首元素地址:%p\n", arr);printf("数组首元素地址:%p\n&

By Ne0inhk