leetcode 1984

1984: 学生分数的最小差值

为方便计算差值,先把 nums 从小到大排序。

把 nums 中的元素画在一维数轴上。如果 numsi 是 k 个数中的最大值,那么最小值的下标至多为 i−k+1(要在最小值和最大值之间再选 k−2 个数)。但最小值越小,差值越大,所以最小值的下标恰好为 i−k+1 是最优的。枚举最小值的下标。

复制代码
class Solution {
public:
    int minimumDifference(vector<int>& nums, int k) {
        int n=nums.size(),ans=INT_MAX;
        if(n==1) return 0;
        ranges::sort(nums);
        for(int i=0;i+k-1<n;i++){
            int diff=nums[i+k-1]-nums[i];
            if(diff<ans) ans=diff;
        }
        
        return ans;
    }
};
相关推荐
珂朵莉MM3 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro1 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort1 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域2 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
2401_868534782 小时前
【无标题】
数据结构·r语言
Mr. zhihao2 小时前
Redis五大高级数据结构:原理-场景-底层-横向对比
数据结构·redis
QiLinkOS2 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
如此这般英俊3 小时前
手撕Claude Code—第一章 agent-loop
数据结构·人工智能·语言模型·自然语言处理
小白兔奶糖ovo3 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll3 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习