差分原理+练习

news2024/11/26 20:46:18

差分的原理和前缀和相似,我们先联想一下前缀和。

前缀和计算下标从0到n的和,记为sum[n+1];如果想要求出[l,r]区间的和,可以快速的通过sum[r+1]-sum[l]来得到 。

前缀和适用于需要多次获取指定连续区间和的情景

差分即计算相邻两个元素的差,记为sub[i]=a[i]-a[i-1](sub[0]=a[0])。为什么要这样做呢?

如果我们对一段连续的区间的数进行同加或同减,那么区间内的sub数组是不会变化的,只有区间分界处的sub数组会发生变化

比如下面的数组:{1,2,3,4,5}

下标01234
a12345
sub11111

现在我们让[1,3]区间,也即2,3,4这三个数都加1,那么下面表格就更改为:

下标01234
a13455
sub12110

最终的效果是sub[1]+=1,sub[4]-=1;

于是有下面的结论:

对于差分数组,如果对原数组a的区间[l,r]同加c(c是个常数,也可以是负的),差分数组sub[l]+=c;sub[r+1]-=c;

而如果我们想还原原数组,通过差分数组也很方便,即对差分数组进行累加求和:

a[i]为下标从[0,i]的差分数组sub之和。

差分数组适用于多次对连续区间进行同加同减操作的情景

以下是两道练习题:

码蹄集 (matiji.net)

本题提到可在区间[l,r]对工资进行修改,完美符合差分的要求。

以下代码可以求出题目所需的差分数组,因为本题编号从1开始,所以本代码下标也是从1开始的,请注意

int n;
cin >> n;
//a是工资数组
for (int i = 1; i <= n; i++)
	cin >> a[i];
//sub是差分数组
//计算差分
sub[1] = a[1];
for (int i = 2; i <= n; i++) {
	sub[i] = a[i] - a[i - 1];
}

现在问题是如何解决题目的问题。

以样例为例,进行分析(本题所指的差分数组不涉及sub[1])

下标12345
a43234
sub本题中不重要-1-111

观察sub数组,题目提到一次操作可以使区间内的所有a都加1或减1,也即通过一次对[l,r]的操作,可以让sub[l]+=1且sub[r+1]-=1(也可能反之)

最终的目的是让所有人工资一样,即sub数组全为0(sub[1]除外)

眼神观察发现,可以操作[3,3]区间和[2,4]区间,让sub[3]+=1,sub[4]-=1;sub[2]+=1,sub[5]-=1,这样就达到sub数组全0的要求了。

实际上,一次操作能让sub数组里的一个数+1,让另一个数-1。设sub数组的所有正数和为P,负数和为-N(即绝对值为N);至少进行P次操作,所有的正数才能都归0;至少进行N次操作,所有的负数才能都归0。而我们可以通过操作让正数-1的同时负数也+1。这样也符合所谓的最少操作次数的要求

比如sub数组里的正数总和为6,负数总和为-4,那么经过4次操作,最后正数总和为2,负数总和为0,这种情况比如:{2,2,2,3,4}这时候再操作两次,就可以让sub数组的元素归0(sub[1]除外)(实际上最后的操作让sub[1]+=1,但是sub[1]在本题无意义,它不能反应工资是否相同)

所以,最少的操作数就是max(P,N),即正负数总和的绝对值中的最大值

以下是完整代码:

#include<iostream>
#include<vector>
using namespace std;
const int N = 1e5 + 10;
int a[N], sub[N];

int main() {
	int n;
	cin >> n;
	//a是工资数组
	for (int i = 1; i <= n; i++)
		cin >> a[i];
	//sub是差分数组
	sub[1] = a[1];//这句话也可以不要,因为在本题sub[1]用不到
	int pos = 0, neg = 0;//pos记录差分数组正数和,neg记录负数和
	for (int i = 2; i <= n; i++) {//从2开始
		sub[i] = a[i] - a[i - 1];
		if (sub[i] > 0) pos += sub[i];
		else neg += sub[i];
	}
	cout << max(pos, -neg);//取绝对值最大的那个
	return 0;
}

下一题

码蹄集 (matiji.net)

(讲解时本题下标依然从1开始,请注意)

我们观察最后一组数据:2 4,可以看到第三匹马高度减少了1.

可以根据题目意思归纳,如果输入是[a,b],那么[a+1,b-1]区间的马匹的高度就会减一(初始值是最高的马高h)。

本题也是明显的连续对区间进行操作,刚好适合差分。

本题难度不高,下面直接给出代码:

#include<iostream>
using namespace std;
const int N = 1e5 + 10;
//sub是差分数组
//本题可以省略高度数组
int n, h, f, sub[N] = { 0 };//差分数组先初始化为0,即默认一开始所有马的高度都是最高高度
int main()
{
    cin >> n >> h >> f;
    //根据前面讲的差分数组的原理,sub[1]=a[1],也即初始高度
    sub[1] = h;
    for (int i = 1; i <= f; i++) {
        int a, b;
        cin >> a >> b;
        //保证a<b
        if (a == b) continue;
        if (a > b) swap(a, b);
        //根据刚刚的分析,真正修改的区间是[a+1,b-1],对应需要修改的差分数组是sub[a+1]和sub[b](可对照开头的原理去理解)
        //注意sub[a+1]是减1,因为对整个区间的操作是高度减1,sub[b]是加1
        sub[a + 1] -= 1; sub[b] += 1;
    }
    //接下来根据差分数组还原原数组的方法,输出每匹马的高度
    //具体还原方法开头的原理也有,就是差分数组求和
    int height = 0;
    for (int i = 1; i <= n; i++) {
        //height是从1到i——[1,i]区间的差分数组之和
        //对应的就是a[i]的值
        height += sub[i];
        cout << height << endl;
    }
    return 0;
}

本文到此就结束了o(* ̄▽ ̄*)ブ 

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

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

相关文章

【Text2SQL 论文】How to prompt LLMs for Text2SQL

论文&#xff1a;How to Prompt LLMs for Text-to-SQL: A Study in Zero-shot, Single-domain, and Cross-domain Settings ⭐⭐⭐⭐ arXiv:2305.11853, NeurlPS 2023 Code: GitHub 一、论文速读 本文主要是在三种常见的 Text2SQL ICL settings 评估不同的 prompt constructio…

Mybatis编写SQL

文章目录 一、用注解编写1.1 增普通增加获取自增ID 1.2 删和改1.3 查单表查询多表查询 二、用xml编写2.1 使用xml的流程2.2 增普通增加获取自增ID 2.3 删 和 改2.4 查 三、#{} 和 ${}3.1 #{} 、${}3.1 预编译 SQL 、即时编译SQL 两种写法是可以同时存在的 一、用注解编写 1.1 …

正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-24.5,6 SPI驱动实验-ICM20608 ADC采样值

前言&#xff1a; 本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM&#xff08;MX6U&#xff09;裸机篇”视频的学习笔记&#xff0c;在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。…

【高校科研前沿】新疆生地所陈亚宁研究员团队在GeoSus发文:在1.5°C和2°C全球升温情景下,中亚地区暴露于极端降水的人口增加

目录 文章简介 1.研究内容 2.相关图件 3.文章引用 文章简介 论文名称&#xff1a;Increased population exposures to extreme precipitation in Central Asia under 1.5 ◦C and 2 ◦C global warming scenarios&#xff08;在1.5C和2C全球变暖情景下&#xff0c;中亚地区…

数学建模 —— 灰色系统(4)

目录 什么是灰色系统&#xff1f; 一、灰色关联分析 1.1 灰色关联分析模型 1.2 灰色关联因素和关联算子集 1.2.1 灰色关联因素 1.2.2 关联算子集 1.3 灰色关联公理与灰色关联度 1.3.1 灰色关联度 1.3.2 灰色关联度计算步骤 1.4 广义关联度 1.4.1 灰色绝对关联…

[AI]大模型训练成本到底有多大?

大模型成本到底有多大&#xff0c;大到太平洋装不下。 上图是早前统计的&#xff0c;目前比较流行的大模型的厂家、模型名称、参数级别和类型。 大模型的成本主要有三块&#xff0c;分别是训练成本、推理成本、储存成本。 大模型的成本确实主要涉及训练成本、推理成本和储存成…

Python 包安装及常用命令【python 入门】

背景&#xff1a; 近期看到一个项目&#xff0c;做微信只能机器人&#xff0c;服务是使用python搭建的&#xff0c;于是拷贝下来自己打算跑一跑&#xff0c;部署一下&#xff0c;可是自己又没有python的经验&#xff0c;于是各种查资料学习&#xff0c;跟着敲一敲&#xff0c;顺…

Signac|成年小鼠大脑 单细胞ATAC分析(1)

引言 在本教程中&#xff0c;我们将探讨由10x Genomics公司提供的成年小鼠大脑细胞的单细胞ATAC-seq数据集。本教程中使用的所有相关文件均可在10x Genomics官方网站上获取。 本教程复现了之前在人类外周血单核细胞&#xff08;PBMC&#xff09;的Signac入门教程中执行的命令。…

【机器学习】使用Stable Diffusion实现潜在空间搜索

1、引言 1.1 潜在空间的概念 潜在空间&#xff08;Latent Space&#xff09;是在机器学习和深度学习中一个重要的概念&#xff0c;它指的是用于表示数据的一种低维空间。这个空间编码了数据中包含的所有有用信息的压缩表示&#xff0c;通常比原始数据空间的维数更低&#xff…

java守护线程介绍

在Java中&#xff0c;守护线程&#xff08;Daemon Thread&#xff09;是一种特殊类型的线程&#xff0c;它在后台默默地运行&#xff0c;为其他线程提供服务。当 JVM 中只剩下守护线程时&#xff0c;JVM 会退出。这意味着&#xff0c;守护线程不应该执行关键的任务&#xff0c;…

COMPUTEX 2024 国际电脑展即将举行,英伟达宣布将Copilot+引入RTX系列设备,赋能游戏本AI助理

COMPUTEX 2024 国际电脑展即将于2024年6月4日至7日在台北南港展览馆1馆及2馆盛大举行。作为业界瞩目的盛会&#xff0c;本次展会不仅吸引了全球各地的科技爱好者&#xff0c;更迎来了AMD CEO苏姿丰博士和NVIDIA首席执行官黄仁勋的精彩演讲。 在展会的开幕之际&#xff0c;图形…

【Python】教你彻底了解Python中的模块和包

​​​​ 文章目录 一、模块的概念1. 导入模块2. 导入特定对象3. 给模块或对象取别名 二、标准库模块1. 常用标准库模块2. 使用示例 三、自定义模块1. 创建模块2. 使用自定义模块 四、包的结构与使用1. 创建包2. 使用包中的模块 五、包的深入使用1. 相对导入2. 子包3. 使用子包…

策略模式+简单工厂

&#x1f347;工厂模式 &#x1f348;工厂模式向策略模式过度——工厂加一个保安 &#x1f34f;策略模式 &#x1f350;策略模式简单工厂 声明本文需要理解多态的基础上才能来学习 欢迎前来学习——继承和多态 学习记录 工厂模式 需要什么就生成什么 // 工厂模式 class Fact…

DP读书:如何使用badge?(开源项目下的标咋用)

最近在冲论坛&#xff0c;很少更一些内容了。但遇到了一个真的有趣的&#xff1a; 开源项目下&#xff0c;蓝蓝绿绿的标是怎么用的呢&#xff1f; 这是我的主页Readme&#xff0c;在看一些NXP的主仓时&#xff0c;突然发现没有这个玩&#xff0c;就自己整了个 再比如我的CSDN专…

php高级之框架源码、宏扩展原理与开发

在使用框架的时候我们经常会看到如下代码 类的方法不会显示地声明在代码里面&#xff0c;而是通过扩展的形式后续加进去&#xff0c;这么做的好处是可以降低代码的耦合度、保证源码的完整性。我自己看着框架源码实现了这个功能。 以下是结果: base代码 index.php <?php…

WPS表格插件方方格子【凑数】功能:选出和等于固定数字的数

文章目录 后来发现可以下载方方格子插件&#xff0c;使用【凑数】功能https://ffcell.lanzouj.com/iwhfc1kjhayh【凑数】快速【凑数】 导师让沾发票&#xff0c;需要选出若干个数额的发票&#xff0c;使它们的和等于一个指定数。不知道怎么办了&#xff0c;查了一下&#xff0c…

【MySQL】数据库入门基础

文章目录 一、数据库的概念1. 什么是数据库2. 主流数据库3. mysql和mysqld的区别 二、MySQL基本使用1. 安装MySQL服务器在 CentOS 上安装 MySQL 服务器在 Ubuntu 上安装 MySQL 服务器验证安装 2. 服务器管理启动服务器查看服务器连接服务器停止服务器重启服务器 3. 服务器&…

三十九、openlayers官网示例Extent Interaction解析——在地图上绘制范围并获取数据

官网demo 地址&#xff1a; Extent Interaction 在openlayers中可以使用ExtentInteraction添加交互事件&#xff0c;配合shiftKeyOnly实现按住shift键绘制边界区域。 const map new Map({layers: [new TileLayer({source: new OSM(),}),],target: "map",view: new …

【贡献度分析(帕累托图)】

文章目录 前言一、贡献度分析是什么&#xff1f;二、使用步骤1. 准备数据2. 排序数据3. 绘制帕累托图4. 分析结果5. 实际应用 三、示例代码 前言 贡献度分析也称为帕累托分析。它可以帮助我们理解数据集中各个因素对整体影响的程度&#xff0c;从而优先处理最重要的因素&#…

oracle数据库通过impdp导入数据时提示,ORA-31684:对象类型用户xxx已存在,和ORA-39151:表xxx存在的解决办法

前提条件&#xff1a;首先备份原数据库中此用户对应的schemas 比如名为cams_wf的schemas 以便出了问题后还可以恢复原数据。 解决办法一、 通过命令或者数据库管理工具删除掉此schemas下的所有表&#xff0c;然后在impdp中加入ignorey 来忽略ORA-31684&#xff1a;对象类型用…