😊博主目前也在学习,有错误欢迎指正😊
🌈保持热爱 奔赴星海🌈
一、题目
1、题目描述
给你一个 下标从 0 开始 的整数数组 nums ,其中 nums[i] 表示第 i 名学生的分数。另给你一个整数 k 。
从数组中选出任意 k 名学生的分数,使这 k 个分数间 最高分 和 最低分 的 差值 达到 最小化 。
返回可能的 最小差值 。
2、基础框架
- Java版本框架代码如下:
class Solution {
public int minimumDifference(int[] nums, int k) {
}
}
3、原题链接
二、解题报告
1、思路分析
(1)先对nums数组进行排序,定义一个大小为k的滑动窗口,计算最大值和最小值差值,移动窗口,每次移动窗口后计算差值,取每次计算的最小值。
2、代码详解
class Solution {
public int minimumDifference(int[] nums, int k) {
Arrays.sort(nums);
int left = 0;
int right = k - 1;
int res = Integer.MAX_VALUE;
while(right < nums.length) {
res = Math.min(nums[right] - nums[left],res);
left++;
right++;
}
return res;
}
}
三、本题知识
滑动窗口