当前位置:首页 > 力扣 > 力扣第1984题精解:如何通过排序将时间复杂度优化到O(n log n)?

力扣第1984题精解:如何通过排序将时间复杂度优化到O(n log n)?

10个月前 (05-14)

力扣第1984题精解:如何通过排序将时间复杂度优化到O(n log n)? C++ 力扣 数组 滑动窗口 算法 排序 第1张

题目解读

给定一个整数数组和一个整数 k,需要找到所有大小为 k 的子数组中最大值与最小值的差值的最小值。例如,数组 [9,4,1,7] 中若 k=2,则子数组有 [9,4](差为5)、[4,1](差为3)、[1,7](差为6),最终结果为3。题目要求通过排序和窗口滑动的思路,高效计算这一最小差值。


解题思路与过程

核心思路是通过排序简化差值计算,具体步骤如下:

1‌.降序排序数组‌:使用自定义比较函数 comp 将数组从大到小排序。降序排列后,每个连续的 k 元素的窗口中,第一个元素是窗口内的最大值,最后一个元素是最小值。

2‌.滑动窗口遍历‌:遍历所有可能的窗口(共 n - k + 1 个),计算当前窗口首尾元素的差值(即最大值与最小值的差),并记录全局最小差值。

3‌.特殊处理 k=1‌:此时所有子数组的差值为0,直接返回。

算法的时间复杂度主要由排序决定(O(n log n)),空间复杂度为 O(n)。通过排序将差值计算简化为首尾元素之差,避免了每个窗口重新遍历查找极值。


代码:

bool comp(int a, int b) { return a > b; }  // 自定义降序排序规则  

class Solution {  
public:  
    int minimumDifference(vector<int>& nums, int k) {  
        if (k == 1) {  // 特殊处理:k=1时差值为0  
            return 0;  
        }  
        int n = nums.size();  
        int newnums[1000];  // 声明临时数组(隐含长度限制)  
        for (int i = 0; i < n; i++) {  
            newnums[i] = nums[i];  // 复制原数组到临时数组  
        }  
        sort(newnums, newnums + n, comp);  // 降序排序  
        int minmum = 100001;  // 初始化为极大值  
        // 滑动窗口遍历所有k长度子数组  
        for (int i = 0; i < n - k + 1; i++) {  
            // 计算当前窗口首尾差值,并更新最小值  
            minmum = min(newnums[i] - newnums[i + k - 1], minmum);  
        }  
        return minmum;  
    }  
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣912排序题终极解法:递归分割 + 双指针合并详解

力扣912排序题终极解法:递归分割 + 双指针合并详解

题目解读给定一个整数数组,要求将其按升序排列并返回。题目通常隐含对算法时间复杂度的要求,理想情况下需实现 O(n log n) 的时间复杂度。本题看似简单,但需要选择合适的排序算法(如归并排序、快速排...

力扣1137题:动态规划解泰波那契数 高效求解第N项的秘密

力扣1137题:动态规划解泰波那契数 高效求解第N项的秘密

一:重新解读题目泰波那契数列是一个充满数学趣味的递推序列:从第3项开始,每个数均为前三个数的和(即Tₙ₊₃ = Tₙ + Tₙ₊₁ + Tₙ₊₂)。当给定整数n时,需要高效计算出第n项的值。面对此类递...

力扣144:递归之美 轻松掌握二叉树前序遍历

力扣144:递归之美 轻松掌握二叉树前序遍历

题目解读二叉树的前序遍历是一种基础但重要的树遍历方式,其遍历顺序为:先访问根节点,然后递归地前序遍历左子树,最后递归地前序遍历右子树。给定一个二叉树的根节点,我们需要按照这个顺序访问所有节点,并将它们...

【力扣3115题解】数组中质数最大差值的求解(C++代码详解)

【力扣3115题解】数组中质数最大差值的求解(C++代码详解)

一、题目解读力扣3115题要求在一个整数数组中,找出两个质数之间的最大差值。若数组不存在质数,则返回0。题目核心在于高效筛选质数,并计算其索引差值的最大值,需兼顾时间与空间复杂度。二、解题思路参考代码...

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

【洛谷1184题解析】用C++高效解决地点匹配问题(附代码与解题思路)

一、题目解读洛谷1184题要求处理一组地点列表与行程记录,统计其中匹配的天数。题目难点在于高效处理带有空格的字符串输入,以及快速判断每日行程是否在高手可去地点集合中。需要兼顾输入格式解析与算法效率。二...

洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)

洛谷P2190题解:铁路售票系统车厢计算(差分数组+前缀和优化)

一、题目解读洛谷P2190题要求解决铁路售票系统中的车厢数量计算问题。题目给定n个车站和m条订票申请,每条申请包含区间[x,y)及乘客数z。需要计算在不超载的情况下(每节车厢最多36人),满足所有乘客...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。