【算法通关指南:算法基础篇】二维差分专题: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

【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
【鼠鼠优选算法-双指针】001:移动零 & 002:复写零

【鼠鼠优选算法-双指针】001:移动零 & 002:复写零

🎈主页传送门:良木生香 🔥个人专栏:《C语言》 《数据结构-初阶》  🌟人为善,福随未至,祸已远行;人为恶,祸虽未至,福已远离 在学习了这么多基础知识之后,我们就从今天开始操练一下我们的基本技能吧,先来两道简单的题目试试手: 1.移动零:题目链接~~~ 2.复写零:复写零 那我们就一题一题来讲讲吧~~~ 一、移动零 题目描述: 看到题目,这道题是想让我们将一个数组中的所有0移动到数组的末尾. 题目意思明了,但是我们该怎么操作呢? 在这道题中我们第一个想到的就是重新创建新的数组,将数值不为0的元素移动到新的数组中,但是题目明确要求说了,只能再原地进操作,我们该怎么实现这个操作呢?又不能创建新的数组不急,我有妙招. 原理解析: 在这道题目中,我们可以用两个指针,current和dentist,一个用来遍历整个数组,另一个用来处理当下的数据 当cur遍历到值为0的元素时,就与dest交换,随后两者同时向后移动一步 但是不管cur碰到的元素是否等于0,都会向后移动一步   代码实现: 下面是用C语言实现的代码: void Swap(

By Ne0inhk
【动态规划:01背包】01背包详解 && 模板题 && 优化

【动态规划:01背包】01背包详解 && 模板题 && 优化

文章目录 * 背包问题概述 * 01 背包(medium) * 1、第一问解题思路 * 状态表示 * 状态转移方程 * 初始化 * 遍历顺序 * 返回值 * 2、第二问解题思路 * 状态表示修改 * 状态转移方程细节修改 * 初始化修改 * 代码 * 💥优化 * 优化后的代码 背包问题概述 终于到了动态规划的一类很有名的问题,背包问题了!为什么背包问题让人听起来就怕呢,因为它是基于动态规划的,本身动态规划就是千变万化,再加上背包问题的一些限定条件,使得背包问题也是分为很多类不同的问题,如 01背包、完全背包等等。 背包问题 (Knapsack problem) 其实也是⼀种组合优化的 NP完全问题。其问题可以描述为:给定⼀组物品,每种物品都有⾃⼰的重量和价格,在限定的总重量内,我们如何选择,才能使得物品的总价格最⾼。 根据物品的个数,分为如下几类: 01 背包问题:每个物品只有一个完全背包问题:

By Ne0inhk