leetcode 910. 最小差值 II 中等

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

对于每个下标 i0 <= i < nums.length),将 nums[i] 变成nums[i] + knums[i] - k

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

在更改每个下标对应的值之后,返回 nums 的最小 分数

示例 1:

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

示例 2:

复制代码
输入:nums = [0,10], k = 2
输出:6
解释:将数组变为 [2, 8] 。分数 = max(nums) - min(nums) = 8 - 2 = 6 。

示例 3:

复制代码
输入:nums = [1,3,6], k = 3
输出:3
解释:将数组变为 [4, 6, 3] 。分数 = max(nums) - min(nums) = 6 - 3 = 3 。

分析:与908 最小差值 I 类似,只是这次的数组必须选择 + k 或者 - k。思路也与908类似,让小的值变大,大的值变小。但是由于数组的每个值都需要变化,可能存在交叉的情况,即数组中间的某个值+k之后比最大值-k要大。为了解决这种情况,我们可以枚举分界点,在分界点左边的值+k,右边的-k。

cpp 复制代码
int cmp(const void *a,const void *b)
{
    int *aa=(int*)a;
    int *bb=(int*)b;
    return *aa-*bb;
}
int smallestRangeII(int* nums, int numsSize, int k) {
    qsort(nums,numsSize,sizeof(nums[0]),cmp);
    int ans=nums[numsSize-1]-nums[0];
    for(int i=numsSize-1;i>0;--i)//枚举分界点
    {//注意每个分界点还要比较分界点的前一个点的情况是否会出现交叉
        if(nums[i]-k>nums[0]+k)ans=fmin(ans,fmax(nums[numsSize-1]-k,nums[i-1]+k)-nums[0]-k);
        else ans=fmin(ans,fmax(nums[numsSize-1]-k,nums[i-1]+k)-nums[i]+k);
    }
    return ans;
}
相关推荐
轮到我狗叫了3 小时前
力扣310.最小高度树(拓扑排序,无向图),力扣.加油站力扣.矩阵置零力扣.二叉树中的最大路径和
算法·leetcode·职场和发展
爱coding的橙子3 小时前
算法刷题Day9 5.18:leetcode定长滑动窗口3道题,结束定长滑动窗口,用时1h
算法·leetcode·职场和发展
小刘不想改BUG4 小时前
LeetCode LCR 010 和为 K 的子数组 (Java)
java·算法·leetcode
小雅痞5 小时前
[Java][Leetcode middle] 12. 整数转罗马数字
java·linux·leetcode
Espresso Macchiato6 小时前
Leetcode 3551. Minimum Swaps to Sort by Digit Sum
leetcode·排序·leetcode medium·leetcode 3551·leetcode周赛450
緈福的街口17 小时前
【leetcode】2900. 最长相邻不相等子序列 I
算法·leetcode·职场和发展
进击的小白菜18 小时前
LeetCode 153. 寻找旋转排序数组中的最小值:二分查找法详解及高频疑问解析
数据结构·算法·leetcode
緈福的街口21 小时前
【leetcode】144. 二叉树的前序遍历
算法·leetcode
Dream it possible!1 天前
LeetCode 热题 100_寻找重复数(100_287_中等_C++)(技巧)(暴力解法;哈希集合;二分查找)
c++·leetcode·哈希算法
小羊在奋斗1 天前
【LeetCode 热题 100】二叉树的最大深度 / 翻转二叉树 / 二叉树的直径 / 验证二叉搜索树
算法·leetcode·职场和发展