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

平滑值(pinghua)

平滑值

题目描述

一个数组的“平滑值”定义为:相邻两数差的绝对值的最大值。
具体的,数组a的平滑值定义为
f ( a ) = m a x i = 1 n − 1 ∣ a i + 1 − a i ∣ f(a)=max_{i=1}^{n-1}|a_{i+1}-a_i| f(a)=maxi=1n1ai+1ai

现在小红拿到了一个数组。她每次操作可以在两个元素之间添加一个整数(不能添加在第一项前面或者最后一项后面)。小红希望最终数组的平滑值恰好等于 k k k,你能帮小红求出最小的操作次数吗?

输入格式

第一行输入两个正整数 n , k n,k n,k,代表数组的大小、以及最终希望达到的平滑值。

第二行输入 n n n个正整数 a i a_i ai。代表小红拿到的数组。

输出格式

一个整数,代表小红最少的操作次数。

样例 #1

样例输入 #1

5 2
1 4 5 1 3

样例输出 #1

2

提示

小红首先在1和4之间插入一个3或2,然后在5和1之间插入一个3即可。

数据范围

2 ≤ n ≤ 1 0 5 2≤n≤10^5 2n105

1 ≤ k , a i ≤ 1 0 9 1≤k,a_i ≤10^9 1k,ai109

/*
分三种情况:
1.max(abs(a[i]-a[i-1]))==k,不用改变,输出 0
2.max(abs(a[i]-a[i-1]))<k,只在某一段做 1 次就行
3.max(abs(a[i]-a[i-1]))>k,枚举每一大于 k 的段,次数为
max/k(向上取整)-1,累加起来就是答案
*/
#include<bits/stdc++.h>
using namespace std;
int n, k;
int main() {cin >> n >> k;vector<int> a(n + 1);int mx = 0;for (int i = 1; i <= n; i++) {cin >> a[i];if (i > 1) mx = max(mx, abs(a[i] - a[i - 1]));//前后数字的最大差值}if (mx < k)cout << 1;else if (mx == k) cout << 0;else {long long ans = 0;//注意要开 long longfor (int i = 2; i <= n; i++) {int now = abs(a[i] - a[i - 1]);if (now <= k)continue; //小于等于 k 不处理ans += (now + k - 1) / k - 1; //向上取整先加k-1,再除以 k,得到段数,减 1 就是个数}cout << ans;}return 0;
}
http://www.lryc.cn/news/364152.html

相关文章:

  • 使用matplotlib绘制折线条形复合图
  • 云计算中网络虚拟化的核心组件——NFV、NFVO、VIM与VNF
  • # SpringBoot 如何让指定的Bean先加载
  • 家用洗地机哪个品牌好?洗地机怎么选?这几款全网好评如潮
  • iOS与前端:深入解析两者之间的区别与联系
  • SpringBoot 基于jedis实现Codis高可用访问
  • 力扣108. 将有序数组转换为二叉搜索树
  • 人工智能机器学习系统技术要求
  • 学习整理使用JavaScript中如何判断变量是否存在的四种常用方法
  • docker实现jenkins+git+naocas一体化自动部署
  • Flutter 中的 PerformanceOverlay 小部件:全面指南
  • es的总结
  • React常见的一些坑
  • Java基础29(编码算法 哈希算法 MD5 SHA—1 HMac 算法 堆成加密算法)
  • 人脸识别——OpenCV
  • 深入探索容器:什么是容器及其在现代软件开发中的作用
  • STM32-- GPIO->EXTI->NVIC中断
  • 【介绍下WebStorm开发插件】
  • 推荐丨一键申请SSL证书,让网站实现HTTPS访问!
  • 交叉导轨在医疗设备上的作用!
  • 【云原生】Docker Compose 使用详解
  • 通过LabVIEW提升生产设备自动化水平
  • 面试题vue+uniapp(个人理解-面试口头答述)未编辑完整....
  • PPP-B2b精密产品使用注意事项及分析
  • C语言(结构体)
  • Python filter()用法:深入解析与实战应用
  • k8s集群的存储卷、pvc和pv
  • 二分搜索树深度优先遍历
  • ImportError: cannot import name ‘packaging‘ from ‘pkg_resources‘‘
  • 灯塔歌曲音乐下载官网