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

LeetCode 0908.最小差值 I:思维(遍历)

title

【LetMeFly】908.最小差值 I:思维(遍历)

力扣题目链接:https://leetcode.cn/problems/smallest-range-i/

给你一个整数数组 nums,和一个整数 k

在一个操作中,您可以选择 0 <= i < nums.length 的任何索引 i 。将 nums[i] 改为 nums[i] + x ,其中 x 是一个范围为 [-k, k] 的整数。对于每个索引 i ,最多 只能 应用 一次 此操作。

nums 的 分数 是 nums 中最大和最小元素的差值。 

在对  nums 中的每个索引最多应用一次上述操作后,返回 nums 的最低 分数

 

示例 1:

输入:nums = [1], k = 0
输出:0
解释:分数是 max(nums) - min(nums) = 1 - 1 = 0。

示例 2:

输入:nums = [0,10], k = 2
输出:6
解释:将 nums 改为 [2,8]。分数是 max(nums) - min(nums) = 8 - 2 = 6。

示例 3:

输入:nums = [1,3,6], k = 3
输出:0
解释:将 nums 改为 [4,4,4]。分数是 max(nums) - min(nums) = 4 - 4 = 0。

 

提示:

  • 1 <= nums.length <= 104
  • 0 <= nums[i] <= 104
  • 0 <= k <= 104

解题方法:遍历

这道题应该如何思考呢?如何将变化后数组中最大值和最小值之差尽可能地小?当然是“大的数尽可能往小的变”、“小的数尽可能往大的变”。

  • 如果 k k k很小,那么最大的数 M M M最多减小到 M − k M-k Mk,最小的数 m m m最多增加到 m + k m+k m+k,最终的最小差值为 M − m − 2 ∗ k M-m-2*k Mm2k
  • 如果 k k k足够大 2 k ≥ M − m 2k\geq M-m 2kMm,那么所有的数都可以变成相同的数,最终最小差值为 0 0 0

因此答案为 max ⁡ { 0 , max ⁡ ( n u m s ) − min ⁡ ( n u m s ) − 2 k } \max\{0, \max(nums)-\min(nums)-2k\} max{0,max(nums)min(nums)2k}

  • 时间复杂度 O ( l e n ( n u m s ) ) O(len(nums)) O(len(nums))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
class Solution {
public:int smallestRangeI(vector<int>& nums, int k) {int M = *max_element(nums.begin(), nums.end());int m = * min_element(nums.begin(), nums.end());return max(0, M - m - 2 * k);}
};
Go
package mainimport "slices"func smallestRangeI(nums []int, k int) int {return max(0, slices.Max(nums) - slices.Min(nums) - 2 * k)
}
Java
class Solution {public int smallestRangeI(int[] nums, int k) {int M = nums[0], m = nums[0];for (int t : nums) {M = Math.max(M, t);m = Math.min(m, t);}return Math.max(0, M - m  - 2 * k);}
}
Python
from typing import Listclass Solution:def smallestRangeI(self, nums: List[int], k: int) -> int:return max(0, max(nums) - min(nums) - 2 * k)

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/143112464

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

相关文章:

  • Python基础之循环语句
  • 项目管理软件真的能让敏捷开发变得更简单吗?
  • 互联网名称之时间戳
  • Leetcode—1242. 多线程网页爬虫【中等】Plus(多线程)
  • RISC-V笔记——内存模型总结
  • 后端常用安全措施
  • 虚拟机数据恢复—通过拼接数据库页碎片的方式恢复数据库的数据恢复案例
  • 【vue】自封组件,基于vue2封装一个弹框组件
  • ES6基础知识
  • 基于Multisim的模拟拔河游戏比赛设计与仿真
  • MyBatis 配置详解
  • 研发运营一体化(DevOps)能力成熟度模型
  • 躺平成长-利用kimi编辑助手帮助自己编程第二天
  • OpenSuse-搭建NFS-Server
  • 【数据结构与算法】之二分查找
  • vue修饰符
  • Oracle里面,with ... as 用法介绍
  • 一个简单的Qt Console Application计算练习程序
  • windows文件拷贝给wsl2的Ubuntu
  • vivado 采用 SSI 器件进行设计
  • Lua环境安装
  • 浏览器控制的无线开关
  • Docker部署SSM项目及避坑指南
  • 多线程代码案例:单例模式/阻塞队列/线程池/定时器
  • Ruby CGI Cookie
  • linux中取消anaconda默认使用base环境
  • 江门中微子到底是做什么的?
  • React源码03 - React 中的更新
  • 【Hive实战】Hive MetaStore升级调研(Mysql)
  • 优化漏洞扫描流程以保障企业数字化业务安全