当前位置:首页 > 力扣 > 力扣第75题新思路:如何用选择排序实现原地操作?

力扣第75题新思路:如何用选择排序实现原地操作?

7个月前 (05-12)

给定一个包含红色、白色和蓝色元素的数组,分别用数字 0、1、2 表示,要求在不使用库排序函数的情况下,仅通过一次遍历(但实际上允许使用经典排序方法)对数组进行原地排序。题目要求将所有 0 排在前面,1 排在中间,2 排在最后,且需要保持元素间的相对顺序。本题的核心是实现一个高效的原地排序算法,但所提供的代码通过经典的选择排序思想完成目标。


力扣第75题新思路:如何用选择排序实现原地操作? 力扣 选择排序 数组 C++ 算法 第1张

选择排序的核心思路是:每次从未排序区间中找到最小值,将其与未排序区间的第一个元素交换,逐步扩展有序区间的范围。具体过程如下:

1‌.外层循环控制有序区间‌:从第一个元素开始,依次向后遍历,每次确定一个位置的最终值。

‌2.内层循环寻找最小值‌:对于当前未排序的位置 i,通过内层循环遍历其后的所有元素,寻找最小值的索引 minIndex。

3‌.元素交换‌:将找到的最小值与当前外层循环的位置 i 的元素交换,确保每次外层循环结束后,区间 [0, i] 是有序的。

4‌.逐步扩展有序范围‌:重复上述过程,直到整个数组有序。

5.时间复杂度为 O(n²),空间复杂度为 O(1)。


代码:

class Solution {
public:
    void sortColors(vector<int>& nums) {
        int n = nums.size();      // 获取数组长度
        int minIndex = 0;         // 记录最小值的位置
        
        // 外层循环:逐步确定每个位置的元素
        for (int i = 0; i < n; i++) {
            minIndex = i;         // 初始最小值位置为当前未排序区间的首位
            
            // 内层循环:在未排序区间中寻找最小值的位置
            for (int j = i + 1; j < n; j++) {
                if (nums[j] < nums[minIndex]) {
                    minIndex = j; // 更新最小值的位置
                }
            }
            
            // 将最小值与当前位置交换,确保当前位置的值是最终结果
            int tmp = nums[i];
            nums[i] = nums[minIndex];
            nums[minIndex] = tmp;
        }
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣654:递归分治的艺术 如何用最大元素构建二叉树

力扣654:递归分治的艺术 如何用最大元素构建二叉树

题目重解我们面对一个看似简单却充满递归魅力的题目:给定一个不含重复元素的整数数组,需要构建一棵特殊的二叉树。这个树的每个父节点都必须是当前子数组中的最大元素,而它的左右子树则分别由该最大值左侧和右侧的...

力扣540题:线性扫描法如何高效定位唯一数

力扣540题:线性扫描法如何高效定位唯一数

题目重解一个严格递增的有序数组中,除某个元素外,其余每个元素均出现两次。这个看似简单的条件背后隐藏着巧妙的规律——单一元素会打破数组的"成对对称性"。题目要求以O(log n)时间...

洛谷1656题解:基于Tarjan算法求解割边问题(附代码与详细步骤)

洛谷1656题解:基于Tarjan算法求解割边问题(附代码与详细步骤)

一、题目解读洛谷1656题要求在无向图中找出所有割边(即删除后导致图不连通的边)。题目核心在于判断图的连通性,并识别哪些边是“桥”。需理解图论中的连通分量概念,以及如何通过算法高效定位割边。二、解题思...

LeetCode 2778题解:平方和的高效计算与因数遍历优化(C++实现)

LeetCode 2778题解:平方和的高效计算与因数遍历优化(C++实现)

一、题目解读LeetCode 2778题要求计算数组中下标为n的因数的元素的平方和。例如,若n=6,其因数为1、2、3、6,则需计算nums[0]、nums[1]、nums[2]、nums[5]的平方...

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

洛谷2652题解析:同花顺排序问题的动态规划与滑动窗口优化

一、题目解读洛谷2652题要求对一组扑克牌进行排序,目标是找到最少需要调整的次数,使得所有牌形成同花顺。题目中,扑克牌由花色和数字组成,需先按花色排序,再在同花色内按数字排序。核心难点在于如何处理花色...

牛客232639题解析:双指针+排序算法高效求解三角形数量(附代码详解)

牛客232639题解析:双指针+排序算法高效求解三角形数量(附代码详解)

一、题目解读牛客232639题要求计算一个整数数组中能够组成有效三角形的三边组合数量。根据三角形不等式,三边需满足任意两边之和大于第三边。例如,数组[3, 4, 5, 6]可组成两个有效三角形([3,...

发表评论

访客

看不清,换一张

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