leetcode 1984

1984: 学生分数的最小差值

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

把 nums 中的元素画在一维数轴上。如果 nums[i] 是 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;
    }
};
相关推荐
田梓燊3 小时前
leetcode 234
算法·leetcode·职场和发展
Aaron15883 小时前
RFSOC+VU13P中在线部分可重构技术的应用分析
人工智能·算法·matlab·fpga开发·重构·信息与通信·信号处理
yashuk4 小时前
C语言入门教程:程序结构与算法举例
c语言·算法·教程·程序设计·开发过程
zsc_1184 小时前
pvz3解码小游戏求解算法 (二)
算法
hanbr4 小时前
每日一题day1(Leetcode 76最小覆盖子串)
算法·leetcode
AI科技星4 小时前
张祥前统一场论中两个电荷定义的统一性解析
开发语言·线性代数·算法·数学建模·平面
代码地平线4 小时前
C语言实现堆与堆排序详解:从零手写到TopK算法及时间复杂度证明
c语言·开发语言·算法
小江的记录本4 小时前
【大语言模型】大语言模型——核心概念(预训练、SFT监督微调、RLHF/RLAIF对齐、Token、Embedding、上下文窗口)
java·人工智能·后端·python·算法·语言模型·自然语言处理
炘爚4 小时前
LeetCode(两两交换链表中的节点)
算法·leetcode·链表
wsoz4 小时前
Leetcode矩阵-day7
c++·算法·leetcode·矩阵