当前位置:首页 > 技术学院 > 技术前线
[导读]基本算法——差分

目标,掌握差分的概念、和解题的思路

差分就是前缀和的逆过程!!!

一维差分

什么是一维差分?


那么差分可以用来干嘛呢?

让我们来看这样一个操作


通过差分,我们可以快速对前缀和数组的一个区间的数进去操作

再思考,如何构建差分呢??需要构建嘛

题目

输入一个长度为n的整数序列。

接下来输入m个操作,每个操作包含三个整数l, r, c,表示将序列中[l, r]之间的每个数加上c。

请你输出进行完所有操作后的序列。

题解


这里需要注意:我们构造差分的方法是insert(i,i,s[i]);

通过插入的方法我们自然而然的就可以得到差分了


模板

a是s的差分,想要对s[l,r]中的一系列数操作

a[l] += val;

a[r+1] -= val;

二维差分

和前缀和类似,我们也有二位差分,就是对一个前缀和的矩阵中一系列数操作

题目

输入一个n行m列的整数矩阵,再输入q个操作,每个操作包含五个整数x1, y1, x2, y2, c,其中(x1, y1)和(x2, y2)表示一个子矩阵的左上角坐标和右下角坐标。

每个操作都要将选中的子矩阵中的每个元素的值加上c。

请你将进行完所有操作后的矩阵输出。

思路还是一样,用差分来做

题解



注意:这里输出的时候用的是BufferWrite()

当要输出大量数据的时候可以使用bw,可以有效节省时间

还有要记得关闭资源哦!!!

模板

public static void insert(int x1, int y1, int x2, int y2, int val){

a[x1][y1] += val;

a[x1][y2+1] -= val;

a[x2+1][y1] -= val;

a[x2+1][y2+1] += val;

}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

为增进大家对工业以太网的认识,本文将对工业以太网的原理、工业以太网的关键技术以及工业以太网要解决的问题予以介绍。

关键字: 以太网 工业以太网 指数

为增进大家对工业以太网的认识,本文将对工业以太网网络优势、工业以太网和IOLINK的区别予以介绍。

关键字: 以太网 工业以太网 指数

为增进大家对工业以太网的认识,本文将对工业以太网的优势、工业以太网缺点、工业以太网的维护予以介绍。

关键字:

Apr. 23, 2024 ---- 随着节能成为AI推理服务器(AI Inference Server)优先考量,北美客户扩大存储产品订单,带动QLC Enterprise SSD需求开始攀升。然而,目前仅Solidi...

关键字: SSD AI 服务器

为增进大家对二极管的认识,本文将对续流二极管、续流二极管的工作原理以及二极管在工业产品中的应用予以介绍。

关键字: 二极管 指数 续流二极管

通过本文,您将了解到二极管反接是否有电压以及二极管在电子电路中的应用。

关键字: 二极管 指数 稳压电路

为增进大家对二极管的了解,本文将对ESD二极管和TVS二极管之间的区别予以介绍。

关键字: ESD TVS 二极管 指数

为增进大家对嵌入式主板的认识,本文将对嵌入式主板以及嵌入式主板常见问题及其解决方法予以介绍。

关键字: 嵌入式 指数 主板

为增进大家对嵌入式系统的认识,本文将对嵌入式系统、嵌入式系统的特点予以介绍。

关键字: 嵌入式 指数 嵌入式系统

为增进大家对嵌入式的认识,本文将对嵌入式、嵌入式工作相关的内容予以介绍。

关键字: 嵌入式 指数 嵌入式技术
关闭
关闭