最小差值(附加单词积累)
title: 最小差值(附加单词积累)
date: 2022-04-12 11:49:14
tags: 每天进步一点点系列
每日题目
题目:最小差值 I
给你一个整数数组 nums,和一个整数 k 。
在一个操作中,您可以选择 0 <= i < nums 的任何索引 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
代码:
class Solution {
public int smallestRangeI(int[] nums, int k) {
int res =0;
int max = Integer.MIN_VALUE;
int min = Integer.MAX_VALUE;
//取最大最小值
for (int num : nums) {
max = Math.max(max, num);
min = Math.min(min, num);
}
//这样取最大最小值速度慢
// Arrays.sort(nums);
// min = nums[0];
// max = nums[nums.length - 1];
//最大值减k,最小值加k,然后算差值res
res = max - min - 2 * k;
//因为k可变,如果res<0,就证明可以把最大最小值变成一样,so,res = 0
if(res < 0) {
res = 0;
}
return res;
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
每日单词
以上就是最小差值(附加单词积累)的全部内容
版权声明:
原创博主:牛哄哄的柯南
博主原文链接:https://keafmd.blog.csdn.net/
个人博客链接:https://www.keafmd.top/
看完如果对你有帮助,感谢点击下面的一键三连支持!
[哈哈][抱拳]
加油!
共同努力!
Keafmd
文章来源: keafmd.blog.csdn.net,作者:牛哄哄的柯南,版权归原作者所有,如需转载,请联系作者。
原文链接:keafmd.blog.csdn.net/article/details/124123043
- 点赞
- 收藏
- 关注作者
评论(0)