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
相关推荐
niuniudengdeng5 分钟前
六面独立转动魔方还原机器人设计与实现
数学·算法·机器人
ghie90907 分钟前
基于MATLAB的A*算法避障路径规划实现
人工智能·算法·matlab
雾岛听蓝19 分钟前
C文件操作与系统IO
linux·c语言·开发语言·经验分享·笔记·算法
zh路西法32 分钟前
【宇树机器人强化学习】(一):PPO算法的python实现与解析
python·深度学习·算法·机器学习·机器人
随意起个昵称34 分钟前
【贪心】选择尽量多的不相交区间
数据结构·算法
章小幽44 分钟前
LeetCode-35.搜索插入位置
数据结构·算法·leetcode
Kiyra1 小时前
如何在面试中优雅地把自己“卖”个好价钱?
面试·职场和发展
放下华子我只抽RuiKe51 小时前
机器学习全景指南-探索篇——发现数据内在结构的聚类算法
人工智能·深度学习·算法·机器学习·语言模型·数据挖掘·聚类
Yupureki1 小时前
《C++实战项目-高并发内存池》3.ThreadCache构造
服务器·c语言·c++·算法·哈希算法
j_xxx404_1 小时前
C++算法:一维/二维前缀和算法模板题
开发语言·数据结构·c++·算法