【C语言刷力扣】910.最小差值 ||

题目:

解题思路;

由于需要对数组中的每一个进行 +k-k 的操作,这时要求最小差值,即对较大的数 -k 对较小的数 + k

需要先对数组进行排序,再枚举对元素的操作。

  • nums [0]nums[i - 1] 的数进行 +k
  • nums [i]nums[numsSize - 1] 的数进行 - k

此时最大数是 nums[i - 1] 或者 nums[numsSize - 1]

最小数是 nums[0] 或者 nums [i]

时间复杂度:

空间复杂度:

复制代码
#define MAX(a,b) (a > b) ? a : b;
#define MIN(a,b) (a < b) ? a : b;

int cmp(const void* a, const void* b) {
    return *(int*)a - *(int*)b;
} 

int smallestRangeII(int* nums, int numsSize, int k) {
    qsort(nums, numsSize, sizeof(int), cmp);
    int max, min;
    int ans = nums[numsSize - 1] - nums[0];
    for (int i = 1; i < numsSize; i++) {
        max = MAX(nums[i-1] + k, nums[numsSize-1] - k);
        min = MIN(nums[0] + k, nums[i] - k);
        ans = MIN(ans, max - min);
    }
    return ans;
}
相关推荐
YUDAMENGNIUBI34 分钟前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2075 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎6 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM7 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮7 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮7 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程
橙淮7 小时前
双指针法:高效算法解题的利器
算法
初心未改HD8 小时前
深度学习之MLP与反向传播算法详解
人工智能·深度学习·算法
刀法如飞8 小时前
【Go 字符串查找的 20 种实现方式,用不同思路解决问题】
人工智能·算法·go