力扣-1984. 学生分数的最小差值

文章目录

力扣题目

给你一个 下标从 0 开始 的整数数组 nums ,其中 numsi 表示第 i 名学生的分数。另给你一个整数 k 。

从数组中选出任意 k 名学生的分数,使这 k 个分数间 最高分 和 最低分 的 差值 达到 最小化 。

返回可能的 最小差值 。

示例 1:

输入:nums = 90, k = 1

输出:0

解释:选出 1 名学生的分数,仅有 1 种方法:

  • 90 最高分和最低分之间的差值是 90 - 90 = 0
    可能的最小差值是 0
    示例 2:

输入:nums = 9,4,1,7, k = 2

输出:2

解释:选出 2 名学生的分数,有 6 种方法:

  • 9,4,1,7 最高分和最低分之间的差值是 9 - 4 = 5
  • 9,4,1,7 最高分和最低分之间的差值是 9 - 1 = 8
  • 9,4,1,7 最高分和最低分之间的差值是 9 - 7 = 2
  • 9,4,1,7 最高分和最低分之间的差值是 4 - 1 = 3
  • 9,4,1,7 最高分和最低分之间的差值是 7 - 4 = 3
  • 9,4,1,7 最高分和最低分之间的差值是 7 - 1 = 6
    可能的最小差值是 2

提示:

1 <= k <= nums.length <= 1000

0 <= numsi <= 105

工程代码

C++实现

cpp 复制代码
class Solution {
public:
    int minimumDifference(vector<int>& nums, int k) 
    {
        int minval = INT_MAX;
        /*升序排列*/
        sort(nums.begin(), nums.end());
        /*区间为[i, i+k-1]的滑动窗口*/
        for(int i = 0; i < nums.size() - k + 1; i++)
        {
            minval = min(minval, nums[i + k - 1] - nums[i]);
        }

        return minval;
    }
};

python实现

cpp 复制代码
class Solution:
    def minimumDifference(self, nums: List[int], k: int) -> int:
        minval = sys.maxsize
        # 升序
        nums.sort()
        # 区间为[i, i+k-1]的滑动窗口
        for i in range(len(nums) - k + 1):
            minval = min(minval, nums[i + k - 1] - nums[i])
        
        return minval
相关推荐
_日拱一卒5 小时前
LeetCode:207课程表
java·数据结构·算法·leetcode·职场和发展
风筝在晴天搁浅8 小时前
美团 LeetCode 692.前K个高频单词
算法·leetcode·职场和发展
z200509309 小时前
今日算法(回溯子集)(模版题)
数据结构·算法·leetcode
YL2004042610 小时前
071字符串解码
数据结构·leetcode
z2005093012 小时前
今日算法(回溯子集)
数据结构·算法·leetcode
Hesionberger12 小时前
巧用异或找出唯一数字(多解)
java·数据结构·python·算法·leetcode
菜菜的顾清寒13 小时前
力扣HOT100(47) 二叉树的层序遍历
算法·leetcode·深度优先
sheeta199814 小时前
LeetCode 每日一题笔记 日期:2026.05.31 题目:2126. 摧毁小行星
笔记·算法·leetcode
INGNIGHT14 小时前
984.不含 AAA 或 BBB 的字符串(贪心)
开发语言·算法·leetcode
人道领域15 小时前
【LeetCode刷题日记】538.把二叉搜索树转换为累加树
java·开发语言·后端·算法·leetcode