当前位置: 首页 > news >正文

C++算法——差分

1.差分

差分与前缀和的核心思想相同,是预处理,可以在暴力枚举的过程中,快速给出查询的结果,从而优化时间复杂度。

是经典的用空间替换时间的做法

补充:使得最短跳跃距离尽可能长,遇到类似这样的问题时,要往 二分、贪心、动态规划 这些算法上考虑

2.一维差分数组

前缀和与差分是⼀对互逆的运算,对差分数组做前缀和运算可以得到原数组。

给定一个数组,对这个数组中某段区间的元素多次进行同时加一个数的操作,如这类的问题,就可以使用差分数组的算法来解决。

模板题目;【模板】差分

进阶题目:P3406 海底高铁 - 洛谷

3.二维差分数组

作用:快速处理“将二维数组中,某一个子矩阵统一加上一个元素”的操作,可以达到O(1)的时间复杂度

性质:对差分矩阵进行前缀和运算后,能够还原出修改之后的原始矩阵。

3.1模板题目

【模板】二维差分

创建差分矩阵也很简单,在全局范围创建二维数组,此时数组每个值都是0,初始化原始矩阵时,每初始化一个元素,就相当于在这个范围中同时加上了一个k,此时差分矩阵进行对应的操作即可。

http://www.dtcms.com/a/58787.html

相关文章:

  • 在Vue中 使用 Web Worker
  • 2025-3-9 一周总结
  • 强化学习(赵世钰版)-学习笔记(4.值迭代与策略迭代)
  • 算力100问☞第80问:如何实现算力的弹性伸缩?
  • 配置 Thunderbird 以使用 QQ 邮箱
  • TinyWebServer项目笔记——02 半同步半反应堆线程池
  • FIWARE:开源的物联网平台,支持设备虚拟化和数据管理
  • java后端开发day30--常见算法(二)-------Arrayslambda
  • 每日一练之合并两个有序链表
  • 【0基础学Python】基础语法Part1
  • Next.js Server Action 提交 vs 前端 Fetch 提交:核心区别与优劣分析
  • 降级选型啊
  • 【向量模型】 开源通用向量模型BGE (BAAI General Embedding)
  • 英文字体:现代复古美学精致细节浓缩式衬线排版logo标题艺术字体 La Luxes Serif
  • 网络安全高级软件编程技术 网络安全 软件开发
  • 蓝桥杯备赛日记【day1】(c++赛道)
  • 解决VScode 连接不上问题
  • OpenWrt 源码目录分析与最终文件系统分析
  • CSS Web安全字体
  • Jump( 2015-2016 ACM-ICPC Northeastern European Regional Contest (NEERC 15). )
  • Autosar技术栈总目录
  • 系统安全阶段练习真题(高软44)
  • 基于DeepSeek与搜索引擎构建智能搜索摘要工具
  • c++:迭代器的失效
  • 星舰(Starship)近地轨道运力极限分析
  • 电路常用常用的定理/定律/计算方法
  • 【开源免费】基于SpringBoot+Vue.JS青年公寓服务平台(JAVA毕业设计)
  • 安装树莓派3B+环境(嵌入式开发)
  • FPGA学习篇——Verilog学习特别篇1(实现功能篇)
  • 神经网络为什么要用 ReLU 增加非线性?