LeetCode hot 100—颜色分类

题目

给定一个包含红色、白色和蓝色、共 n个元素的数组 nums ,**原地**对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。

我们使用整数 012 分别表示红色、白色和蓝色。

必须在不使用库内置的 sort 函数的情况下解决这个问题。

示例

示例 1:

复制代码
输入:nums = [2,0,2,1,1,0]
输出:[0,0,1,1,2,2]

示例 2:

复制代码
输入:nums = [2,0,1]
输出:[0,1,2]

分析

三指针法

初始化指针

  • left 指针初始化为 0,用于标记 0 应该存放的位置。
  • right 指针初始化为 nums.size() - 1,用于标记 2 应该存放的位置。
  • current 指针初始化为 0,用于遍历数组。

遍历数组

  • current 指针小于等于 right 指针时,进行以下操作:
  • 如果 nums[current] 等于 0,说明当前元素是红色,将其与 left 位置的元素交换,并将 leftcurrent 指针都向后移动一位。
  • 如果 nums[current] 等于 2,说明当前元素是蓝色,将其与 right 位置的元素交换,并将 right 指针向前移动一位。注意,此时 current 指针不移动,因为交换过来的元素还需要再次判断。
  • 如果 nums[current] 等于 1,说明当前元素是白色,直接将 current 指针向后移动一位。

结束条件

  • current 指针大于 right 指针时,遍历结束,数组已经按照 0、1、2 的顺序排列好。

时间复杂度:O(), 是数组的长度

空间复杂度:O(1)

cpp 复制代码
class Solution {
public:
    void sortColors(std::vector<int>& nums) {
        int left = 0;  // 指向 0 应该存放的位置
        int right = nums.size() - 1;  // 指向 2 应该存放的位置
        int current = 0;  // 当前遍历到的元素位置
        while (current <= right) {
            if (nums[current] == 0) {
                // 如果当前元素是 0,将其与 left 位置的元素交换
                std::swap(nums[current], nums[left]);
                left++;
                current++;
            } else if (nums[current] == 2) {
                // 如果当前元素是 2,将其与 right 位置的元素交换
                std::swap(nums[current], nums[right]);
                right--;
            } else {
                // 如果当前元素是 1,直接移动到下一个元素
                current++;
            }
        }
    }
};
相关推荐
悦悦子a啊3 分钟前
PTA:jmu-ds-最短路径
c++·算法·图论
Kidddddult21 分钟前
力扣刷题Day 46:搜索二维矩阵 II(240)
算法·leetcode·力扣
小王努力学编程40 分钟前
高并发内存池(三):TLS无锁访问以及Central Cache结构设计
jvm·数据结构·c++·学习
草莓啵啵~1 小时前
数据结构--二叉树
数据结构
Watink Cpper1 小时前
[数据结构高阶]并查集初识、手撕、可以解决哪类问题?
数据结构·图论··并查集
不是吧这都有重名2 小时前
[论文阅读]Deeply-Supervised Nets
论文阅读·人工智能·算法·大语言模型
homelook2 小时前
matlab simulink双边反激式变压器锂离子电池均衡系统,双目标均衡策略,仿真模型,提高均衡速度38%
算法
什码情况3 小时前
星际篮球争霸赛/MVP争夺战 - 华为OD机试真题(A卷、Java题解)
java·数据结构·算法·华为od·面试·机试
天上路人3 小时前
采用AI神经网络降噪算法的通信语音降噪(ENC)模组性能测试和应用
人工智能·神经网络·算法
字节高级特工3 小时前
【C++】”如虎添翼“:模板初阶
java·c语言·前端·javascript·c++·学习·算法