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

【算法实战】每日一题:将某个序列中内的每个元素都设为相同的值的最短次数(差分数组解法,附概念理解以及实战操作)

题目

将某个序列中内的每个元素都设为相同的值的最短次数

1.差分数组(后面的减去前面的值存储的位置可以理解为中间)

差分数组用于处理序列中的区间更新和查询问题。它存储序列中相邻元素之间的差值,而不是直接存储每个元素的值

怎么对某一段区间的值增加X

利用差分数组的特性来实现对某个区间 [L, R] 内的每个元素增加一个值 X 的操作。

差分数组存储的是每个元素与其前一个元素之间的差值。

在区间的起始位置 L 处将差分数组增加 X,相当于将该区间后面的所有元素都增加了 X。

然后,在区间的结束位置 R+1 处将差分数组减去 X,以抵消掉对后续元素的影响。这样就实现了对整个区间内每个元素增加 X 的操作。

2. 解决方案思路

在差分数组中,可以执行两种操作:对于正数和负数构成的区间,可以对区间内的每个值增加或减少一个数来实现值相同;(本质上是一种相互抵消)

对于那些无法配对的正数或负数,可以考虑将当前位置与超出序列范围的位置进行操作,相当于是右边的区间内所有值都受到影响。

基于这个思路,我们可以通过统计序列中正数和负数的个数,通过第一种操作将它们抵消,然后通过第二种操作将剩余的正数或负数变成 0,从而实现所有值相同的目标。

在这个问题中,实际上是要求找到序列中正数或负数的最大值,以确定最少的调整次数,使得所有值相同。(注意这里不是正负数的个数,而是正负数里面的最大值)

3. 解决方案

.
def main():n = int(input())a=[]for i in range(n):a.append(int(input()))passsub = [0] * (n+1)num1 = 0num2 = 0for i in range(1,n):sub[i] = a[i] - a[i - 1]if sub[i] > 0:num1 += sub[i] else:num2 += sub[i]print(max(num1, -num2))if __name__ == '__main__':main()

END

http://www.lryc.cn/news/359432.html

相关文章:

  • EXCEL数据透视图中的日期字段,怎样自动分出年、季度、月的功能?
  • 【设计模式深度剖析】【1】【行为型】【模板方法模式】| 以烹饪过程为例加深理解
  • JAVA:异步任务处理类CompletableFuture让性能提升一倍
  • 10Linux 进程管理学习笔记
  • 一些关于深度聚类以及部分对比学习的论文阅读笔记
  • 【ARM-Linux篇】u-boot编译
  • Lombok一文通
  • Seq2Seq模型:详述其发展历程、深远影响与结构深度剖析
  • 公网如何访问内网?
  • 手机定制开发_基于天玑900的5G安卓手机定制方案
  • 免费,C++蓝桥杯等级考试真题--第2级
  • panic 、asset、crash 的含义和区别
  • 解决Windows 10通过SSH连接Ubuntu 20.04时的“Permission Denied”错误
  • Windows 下 PostgreSQL 图形化界面安装、配置详解
  • 曾巩,散文的艺术与哲思
  • 【SpringBoot】怎么在一个大的SpringBoot项目中创建多个小的SpringBoot项目,从而形成子父依赖
  • vue3组件通信与props
  • 并发和异步编程:详细概述
  • 交易员摩拳擦掌,就在今年夏天,极端气候引爆商品?
  • 数据结构学习笔记
  • vscode导入自定义模块报错ModuleNotFoundError解决方案
  • go mod包管理与应用,常见错误排查方法
  • 数据结构作业
  • 项目纪实 | 版本升级操作get!GreatDB分布式升级过程详解
  • 富格林:应用正规技巧阻挠被骗
  • 【模型架构】学习RNN、LSTM、TextCNN和Transformer以及PyTorch代码实现
  • 【LeetCode】38.外观数列
  • 如何解决Ubuntu中软件包安装时的404错误(无法安装gdb、cgddb等)
  • SpringBoot中MyBatisPlus的使用
  • 前后端交互:axios 和 json;springboot 和 vue