news 2026/4/16 15:01:32

LeetCode 1984.学生分数的最小差值:排序(类似滑动窗口)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 1984.学生分数的最小差值:排序(类似滑动窗口)

【LetMeFly】1984.学生分数的最小差值:排序(类似滑动窗口)

力扣题目链接:https://leetcode.cn/problems/minimum-difference-between-highest-and-lowest-of-k-scores/

给你一个下标从 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

解题方法:排序

n u m s numsnums排序,返回所有长度为k kk的子数组中d i f f ( l a s t , f i r s t ) diff(last, first)diff(last,first)的最小值即可。

  • 时间复杂度O ( N 2 ) O(N^2)O(N2)
  • 空间复杂度O ( N log ⁡ N ) O(N\log N)O(NlogN)

AC代码

C++
/* * @LastEditTime: 2026-01-25 10:33:04 */classSolution{public:intminimumDifference(vector<int>&nums,intk){sort(nums.begin(),nums.end());intans=100000;for(inti=0;i+k-1<nums.size();i++){ans=min(ans,nums[i+k-1]-nums[i]);}returnans;}};
Python
''' LastEditTime: 2026-01-25 10:37:04 '''fromtypingimportListclassSolution:defminimumDifference(self,nums:List[int],k:int)->int:nums.sort()returnmin(nums[i+k-1]-nums[i]foriinrange(len(nums)-k+1))
Java
/* * @LastEditTime: 2026-01-25 10:40:30 */importjava.util.Arrays;classSolution{publicintminimumDifference(int[]nums,intk){intans=100000;Arrays.sort(nums);for(inti=0;i+k-1<nums.length;i++){ans=Math.min(ans,nums[i+k-1]-nums[i]);}returnans;}}
Go
/* * @LastEditTime: 2026-01-25 10:39:56 */packagemainimport"sort"funcminimumDifference(nums[]int,kint)int{ans:=100000sort.Ints(nums)fori:=0;i<len(nums)-k+1;i++{ans=min(ans,nums[i+k-1]-nums[i])}returnans}
Rust
/* * @LastEditTime: 2026-01-25 10:43:39 */implSolution{pubfnminimum_difference(mutnums:Vec<i32>,k:i32)->i32{letk=kasusize;letmutans=100000;nums.sort();foriin0..nums.len()-k+1{ans=ans.min(nums[i+k-1]-nums[i]);}ans}}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 23:34:09

《枪炮、病菌与钢铁:人类社会的命运》书评与推荐文章

《枪炮、病菌与钢铁&#xff1a;人类社会的命运》书评与推荐文章 引言&#xff1a;一个问题的力量 1972年7月&#xff0c;在新几内亚的热带雨林中&#xff0c;一位年轻的美国生物学家贾雷德戴蒙德正在进行鸟类演化研究。在那里&#xff0c;他遇到了当地政治家耶利&#xff0c…

作者头像 李华
网站建设 2026/4/14 10:41:32

基于51单片机红外线感应自动门 液晶显示 自动 手动

目录 系统概述硬件组成功能实现核心代码片段注意事项 源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 系统概述 基于51单片机的红外线感应自动门系统结合了红外传感、液晶显示和自动/手动控制功能。该系统通过红外传感器检测人体信号&…

作者头像 李华
网站建设 2026/4/15 15:32:51

Linux软件安装 —— Elasticsearch集群安装(带密码验证)

文章目录一、节点说明二、JDK安装三、Elasticsearch安装1、软件下载2、基础环境准备(三节点)3、修改配置4、启动集群5、修改密码6、远程连接一、节点说明 IP主机名192.168.10.102node02192.168.10.103node03192.168.10.104node04二、JDK安装 参考本人此篇文章&#xff1a;Lin…

作者头像 李华
网站建设 2026/4/16 10:57:31

2026年实测有效!4款强力降AI工具对比,教你如何有效降低文章AI率

毕业论文降AI率这件事&#xff0c;真的是每年毕业季的“硬核话题”。不少同学都经历过这种情况&#xff1a;辛辛苦苦改了一百遍&#xff0c;AI检测率还是不降&#xff0c;眼看交稿日期越来越近&#xff0c;自己都快抓狂了&#xff0c;到底该怎么办&#xff1f; 不要急&#xff…

作者头像 李华
网站建设 2026/4/16 11:05:03

什么是 Spring IOC?

Spring IOC&#xff08;控制反转&#xff09;详解 一、什么是 IOC IOC&#xff08;Inversion of Control&#xff0c;控制反转&#xff09; 是一种设计思想&#xff0c;不是什么技术实现。它指的是将对象的创建、管理和依赖关系的控制权从程序代码本身转移到外部容器&#xf…

作者头像 李华