题解 | #数组移动# #颜色分类#

颜色分类

https://www.nowcoder.com/practice/52e04ddb7b5640a8869c2d3da2ad3344

#coding:utf-8
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param colors int整型一维数组 
# @return int整型一维数组
#
class Solution:
    def sortColor(self , colors ):
        # write code here
        n = len(colors)
        left = 0
        right = n - 1
        i = 0 #i是移动的指针
        while i <= right:
            #如果遇到2 放到最右边
            while i <= right and colors[i] == 2:
                tmp = colors[i]
                colors[i] = colors[right]
                colors[right] = tmp
                right -= 1
            #如果遇到0 放到左边
            if colors[i] == 0:
                tmp = colors[i]
                colors[i] = colors[left]
                colors[left] = tmp
                left += 1
            i += 1
        return colors
            

全部评论
颜色版的快速排序
点赞 回复 分享
发布于 2024-05-16 21:13 北京
精辟题目
点赞 回复 分享
发布于 2024-05-16 21:13 北京
x1
点赞 回复 分享
发布于 2024-05-13 18:45 北京

相关推荐

积极的小学生不要香菜:你才沟通多少,没500不要说难
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务