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
相关推荐
djarmy23 分钟前
C 标准库 `<stdio.h>` 完整函数清单(官方标准 + 常用全部函数)
c语言·c++·算法
七牛云行业应用28 分钟前
NotebookLM 手机版上线了,这份完整指南帮你把它用起来
算法
城事漫游Molly32 分钟前
定量研究设计清单:问卷、实验与变量操作化怎么做?
大数据·人工智能·算法·ai写作·论文笔记
Epiphany.55634 分钟前
带依赖关系的最短路问题
算法
Kiyra39 分钟前
限流不是加个计数器就行:用 Lua 脚本实现多维度原子限流
开发语言·人工智能·网络协议·职场和发展·架构·lua·ai-native
洛水水1 小时前
【力扣100题】22. 矩阵置零
算法·leetcode·矩阵
Liangwei Lin1 小时前
LeetCode 78. 子集
数据结构·算法·leetcode
多加点辣也没关系1 小时前
数据结构与算法|第二十四章:算法思维总结与实战
算法·代理模式
programhelp_1 小时前
SIG(Susquehanna)SDE 面试面经 | 2026 亲身经历分享
面试·职场和发展
炽烈小老头1 小时前
【每天学习一点算法 2026/05/11】排序链表
学习·算法·链表