本文正在参与掘金团队号上线活动,点击 查看大厂春招职位
题目链接: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
四、总结
这类需要在原地移动的题,往往从为每个下标找合适的数的思路出发更清晰。
如果你觉的还不错的话,给我点个赞吧💐