「每日LeetCode」2022年2月11日

本文最后更新于:2023年3月19日 晚上

1984.学生分数的最小差值

1984.学生分数的最小差值

Category Difficulty Likes Dislikes
algorithms Easy (57.47%) 25 -

Tags
Companies
给你一个 下标从 0 开始 的整数数组 nums ,其中 nums[i] 表示第 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 <= nums[i] <= 105

思路

排序后滑动窗口逐个遍历,计算最大最小值分差更新记录即可

解答

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
/*
* @lc app=leetcode.cn id=1984 lang=javascript
*
* [1984] 学生分数的最小差值
*/

// @lc code=start
/**
* @param {number[]} nums
* @param {number} k
* @return {number}
*/
var minimumDifference = function (nums, k) {
if (k === 1) return 0;
nums.sort((a, b) => +a - +b);
let res = Infinity;
for (let i = 0; i < nums.length - k + 1; i++) {
const arr = nums.slice(i, i + k);
const min = arr[0],
max = arr[arr.length - 1];
res = Math.min(res, max - min);
}
return res;
};
// @lc code=end