LeetCode 75. 颜色分类|刷题打卡

208 阅读1分钟

本文正在参与掘金团队号上线活动,点击 查看大厂春招职位

题目链接:LeetCode 75. 颜色分类
难度:中等

一、题目描述

给定一个包含红色、白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。
此题中,我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。
示例 1:

输入:nums = [2,0,2,1,1,0]
输出:[0,0,1,1,2,2]

示例 2:

输入:nums = [2,0,1]
输出:[0,1,2]

示例 3:

输入:nums = [0]
输出:[0]

示例 4:

输入:nums = [1]
输出:[1]

提示:

  • n == nums.length
  • 1 <= n <= 300
  • nums[i] 为 0、1 或 2

进阶:

  • 你可以不使用代码库中的排序函数来解决这道题吗?
  • 你能想出一个仅使用常数空间的一趟扫描算法吗?

二、思路分析

从0开始,为每个下标找合适的数。因为是按0,1,2这样排,所以先找0的,再找1,最后找2。具体看代码把。

三、AC 代码

python

    def sortColors(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        # 双指针,一个是目标,一个是当前位置
        index, p = 0, 0
        n = len(nums)
        find = 0
        while p < n and index < n:
            while p < n and nums[p] != find: # 找到下一个为目标颜色的下标
                p+=1 
            if p == n or nums[p] != find: # 如果越界就切换到下一个颜色或者结束
                if find > 2:
                    break
                else: # 找下一个颜色
                    find+=1
                    p = index
            else: # 交换一下位置
                nums[index],nums[p] = nums[p],nums[index]
                index += 1
                p = index

四、总结

这类需要在原地移动的题,往往从为每个下标找合适的数的思路出发更清晰。

如果你觉的还不错的话,给我点个赞吧💐