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
相关推荐
Tisfy几秒前
LeetCode 3629.通过质数传送到达终点的最少跳跃次数:埃式筛+BFS
算法·leetcode·宽度优先·质数·埃式筛
Hello.Reader6 分钟前
算法基础(九)——循环不变式如何证明一个算法是正确的
java·开发语言·算法
wuweijianlove8 分钟前
算法稳定性分析中的输入扰动建模的技术7
算法
MATLAB代码顾问15 分钟前
粒子群优化算法(PSO)原理与Python高级实现
开发语言·python·算法
Epiphany.55617 分钟前
连通块的遍历
c++·算法·蓝桥杯
alxraves28 分钟前
超声诊断图像的关键算法概述
算法·安全·健康医疗·制造·信号处理
mask哥32 分钟前
15种算法模式java实现详解
java·算法·力扣
若尘79733 分钟前
数学idea的重构
算法·职场和发展·机器人
思茂信息34 分钟前
CST可重构雷达吸波器设计与仿真
网络·算法·平面·智能手机·重构·cst·电磁仿
游乐码35 分钟前
c#插入排序
数据结构·算法·排序算法