【LeetCode】每日一题 2024_10_20 最小差值 I(模拟/数学/贪心)

前言

每天和你一起刷 LeetCode 每日一题~

LeetCode 启动!

题目:最小差值 I

代码与解题思路

今天的题目也比较简单,题目要求找到数组的最大值和最小值相减的最小值,每个元素可以 +k 或者 -k,那最优的情况就是让最大值 -k,最小值 +k,转化一下就是让:最大值 - 最小值 - 2*k 就能得到题目想要的值。分类讨论一下可能出现的结果即可:

1、最大值 - 最小值 - 2*k <= 0,那就直接返回 0 即可

2、最大值 - 最小值 - 2*k > 0,那就直接返回这个结果

以下是代码:

go 复制代码
func smallestRangeI(nums []int, k int) int {
    // 找最大值和最小值和差并与 k 比较即可
    mi, mx := math.MaxInt, math.MinInt
    for _, v := range nums {
        mi = min(mi, v)
        mx = max(mx, v)
    }
    if mx - mi <= k * 2 {
        return 0
    }
    return mx - mi - k * 2
}

当时看完题目没多想就直接上手实现了,写完才想起来,求数组的最大最小元素这种需求,语言自带的包一般都有能直接使用的实现:

go 复制代码
func smallestRangeI(nums []int, k int) int {
    return max(slices.Max(nums)-slices.Min(nums)-2*k, 0)
}   

原本的写法写了两分钟,一用上包,一行就搞定了

小聊两句

其实力扣每日一题的难度比较随机,经常出特别简单抑或是特别难的题目,所以刷力扣每日一题更重要的是帮助我们养成一个每天坚持刷题的习惯~

每天进步一点点,我们明天不见不散~

可以和我刷一辈子的每日一题吗?

一题一题,积累起来就是一辈子。

相关推荐
咋吃都不胖lyh12 分钟前
GBDT 中的前向分布算法和贪婪学习
学习·算法
leo__52015 分钟前
CLEAN算法仿真程序,用于雷达信号中的杂波抑制
算法
一分之二~26 分钟前
二叉树--求最小深度(迭代和递归)
数据结构·c++·算法·leetcode·深度优先
老鼠只爱大米27 分钟前
LeetCode经典算法面试题 #24:两两交换链表中的节点(迭代法、递归法等多种实现方案详细解析)
算法·leetcode·链表·递归·双指针·迭代·链表交换
mjhcsp27 分钟前
挑战训练一个 AlphaZero 五子棋
算法·洛谷
Word码43 分钟前
leetcode260.只出现一次的数字III
算法
MM_MS1 小时前
Halcon图像采集助手、ROI操作和画图、ROI实现区域与轮廓之间的相互转换、区域的交集差集取反
图像处理·人工智能·数码相机·算法·目标检测·计算机视觉·视觉检测
智者知已应修善业1 小时前
【输出一个N*N的01矩阵,表示最后的汉字点阵图】2024-10-22
c语言·数据结构·c++·经验分享·笔记·算法·矩阵
uesowys1 小时前
华为OD算法开发指导-二级索引
数据结构·算法·华为od
a程序小傲2 小时前
高并发下如何防止重复下单?
java·开发语言·算法·面试·职场和发展·状态模式