LeetCode讲解篇之75. 颜色分类

文章目录

题目描述

题解思路

我们可以将最终结果看成连续的三个区间,第一个区间内全是0,第二个区间内全是1,第三个区间内全是2

,其中这三个区间的长度都可以为0

我们可以将不断扩张

复制代码
我们记录0区间的右边界的下一个位置和2区间的左边界的下一个位置
在遍历过程中
遇到0,交换当前元素和0区间右边界的元素,然后0区间的右边界向后扩张,如果左边界的索引大于等于当前遍历的元素的索引,则当前元素索引后移
遇到1,则索引后移
遇到2,交换当前元素和2区间左边界的元素,然后2区间的左边界向前扩张

题解代码

python 复制代码
class Solution:
    def sortColors(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        left, right = 0, len(nums) - 1
        i = 0
        while i <= right:
            if nums[i] == 0:
                nums[i], nums[left] = nums[left], nums[i]
                left += 1
                if left >= i:
                    i += 1
            elif nums[i] == 1:
                i += 1
            else:
                nums[i], nums[right] = nums[right], nums[i]
                right -= 1
相关推荐
qq_4335545418 分钟前
C++ Dijkstra堆优化算法
开发语言·c++·算法
楼田莉子2 小时前
C++动态规划算法:斐波那契数列模型
c++·学习·算法·动态规划
1373i2 小时前
【Python】通俗理解反向传播
深度学习·算法·机器学习
Madison-No72 小时前
【C++】日期类运算符重载实战
c++·算法
cici158742 小时前
基于K-SVD的稀疏编码去噪算法
算法
电力程序小学童2 小时前
基于密集型复杂城市场景下求解无人机三维路径规划的Q-learning算法研究(matlab)
算法·matlab·无人机
小柯J桑_2 小时前
Linux:线程控制
linux·c++·算法
1白天的黑夜13 小时前
栈-1047.删除字符串中的所有相邻重复项-力扣(LeetCode)
c++·leetcode·
im_AMBER3 小时前
Leetcode 18 java
java·算法·leetcode
wzx_Eleven3 小时前
【论文阅读】Towards Privacy-Enhanced and Robust Clustered Federated Learning
论文阅读·人工智能·算法·机器学习·支持向量机·网络安全