news 2026/4/15 14:45:48

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/3 6:09:28

基于SpringBoot的社区老人健康信息管理系统毕业设计源码

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。 一、研究目的 本研究旨在设计并实现一个基于SpringBoot框架的社区老人健康信息管理系统。该系统旨在通过整合现代信息技术与社区养老服务&#xff0c;提高社区老人健康管理…

作者头像 李华
网站建设 2026/4/13 16:35:27

强烈安利9个AI论文软件,专科生轻松搞定毕业论文!

强烈安利9个AI论文软件&#xff0c;专科生轻松搞定毕业论文&#xff01; AI 工具的崛起&#xff0c;让论文写作不再难 对于专科生来说&#xff0c;撰写毕业论文往往是一道难以逾越的门槛。从选题、查找资料到撰写初稿、反复修改&#xff0c;每一个环节都可能让人感到力不从心。…

作者头像 李华
网站建设 2026/3/26 21:19:22

基于51单片机的智能窗帘晾衣架 WIFI传输 防盗报警

目录基于51单片机的智能窗帘晾衣架系统概述核心功能模块硬件设计要点软件逻辑流程扩展应用场景注意事项源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;基于51单片机的智能窗帘晾衣架系统概述 该系统结合51单片机作为主控芯片&#xff…

作者头像 李华
网站建设 2026/4/11 2:04:31

基于51单片机的智能药盒 WIFI传输 药量检测 定时吃药

目录 功能概述硬件设计软件设计应用场景扩展功能 源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01; 功能概述 基于51单片机的智能药盒整合了WIFI传输、药量检测和定时提醒功能&#xff0c;旨在帮助用户规律服药。系统通过传感器监测药量…

作者头像 李华