最小差值(附加单词积累)

举报
牛哄哄的柯南 发表于 2022/04/13 00:05:46 2022/04/13
【摘要】 title: 最小差值(附加单词积累) date: 2022-04-12 11:49:14 tags: 每天进步一点点系列 每日题目 题目:最小差值 I 给你一个整数数组 nums,和...

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

每日单词

image-20220412120606361

以上就是最小差值(附加单词积累)的全部内容

版权声明:
原创博主:牛哄哄的柯南
博主原文链接:https://keafmd.blog.csdn.net/
个人博客链接:https://www.keafmd.top/

看完如果对你有帮助,感谢点击下面的一键三连支持!
[哈哈][抱拳]

请添加图片描述在这里插入图片描述
加油!

共同努力!

Keafmd

文章来源: keafmd.blog.csdn.net,作者:牛哄哄的柯南,版权归原作者所有,如需转载,请联系作者。

原文链接:keafmd.blog.csdn.net/article/details/124123043

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。