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

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

2周前 (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;
        }
    }
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣LCR182:字符串操作三连 从基础拼接到底层指针优化

力扣LCR182:字符串操作三连 从基础拼接到底层指针优化

题目重解需要将密码字符串从第target个字符开始进行重新排列,形成新的动态密码。例如输入"password"和target=3,结果应为"swordpas"。...

力扣53题:贪心策略与动态规划的完美联姻 三行代码映射算法精髓

力扣53题:贪心策略与动态规划的完美联姻 三行代码映射算法精髓

题目理解在数字的海洋中寻找最具价值的珍珠链:当我们面对一个可能包含正负数的数组时,寻找连续子数组的和最大值就像在波动的股票曲线中捕捉最佳投资时段。问题的核心在于如何处理可能降低总和的负值元素——是忍痛...

力扣746:三步通关最小花费爬楼梯

力扣746:三步通关最小花费爬楼梯

题目解析:站在楼梯的某个台阶时,需要支付当前台阶对应的体力值cost[i],之后可以选择向上爬1或2个台阶。最终目标是到达‌楼层顶部‌(即数组末尾之后的位置),且初始位置可选择下标0或1的台阶作为起点...

力扣119题:从O(n²)到O(2n):杨辉三角高效空间优化

力扣119题:从O(n²)到O(2n):杨辉三角高效空间优化

题目重解:给定一个非负索引 rowIndex,返回杨辉三角的第 rowIndex 行。不同于生成整个杨辉三角,这道题要求我们只返回特定行,且空间复杂度应尽可能优化。例如输入3,需要返回[1,3,3,1...

力扣第92题:三步定位 精准反转链表指定区间

力扣第92题:三步定位 精准反转链表指定区间

题目解读给定一个单链表和两个整数left与right,要求将链表中从第left个节点到第right个节点的部分进行反转,而保持其他部分不变。例如,对于链表1→2→3→4→5,left=2,right=...

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

题目解读给定一个整数数组,我们需要找到一个中心索引,使得该索引左侧所有元素的和等于右侧所有元素的和。如果不存在这样的索引,则返回-1。中心索引的定义不包含在左右两侧的和计算中。这个问题考察对数组遍历和...

发表评论

访客

看不清,换一张

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