【从零开始的LeetCode-算法】908. 最小差值 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 <= 10^4
  • 0 <= nums[i] <= 10^4
  • 0 <= k <= 10^4
java 复制代码
class Solution {
    public int smallestRangeI(int[] nums, int k) {
        if(nums.length == 1) return 0;
        Arrays.sort(nums);
        return Math.max(0,nums[nums.length - 1] - nums[0]  - 2 * k);
    }
}
相关推荐
羊小猪~~几秒前
算法/力扣--栈与队列经典题目
开发语言·c++·后端·考研·算法·leetcode·职场和发展
Noushiki几秒前
数据一致性保障方案 -java后端
java·开发语言
扶摇接北海1761 分钟前
洛谷:P1035 [NOIP 2002 普及组] 级数求和
算法
WitsMakeMen5 分钟前
RankMixer论文理解
算法
Meepo_haha5 分钟前
Maven Spring框架依赖包
java·spring·maven
studyForMokey5 分钟前
【Android面试】ViewModel & LiveData & EventBus专题
android·java·面试
迷藏4948 分钟前
# 发散创新:用Rust构建高性能分布式账本节点——从零实现共识算法与链上数据存储
java·python·rust·共识算法·分布式账本
Flittly10 分钟前
【SpringAIAlibaba新手村系列】(5)Prompt 提示词基础与多种消息类型
java·笔记·spring·ai·springboot
思茂信息10 分钟前
基于 CST 的方向图可重构天线仿真分析
网络·人工智能·单片机·算法·重构·cst·电磁仿真
IronMurphy10 分钟前
【算法三十三】17. 电话号码的字母组合
算法