码迷,mamicode.com
首页 > 其他好文 > 详细

75. 颜色分类 leetcode

时间:2020-03-07 20:44:35      阅读:56      评论:0      收藏:0      [点我收藏+]

标签:颜色   return   color   技术   元素   整数   ret   sel   红色   

给定一个包含红色、白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。

此题中,我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。

技术图片

 

 

class Solution:
    def sortColors(self, nums: List[int]) -> None:
        """
        Do not return anything, modify nums in-place instead.
        """
        right_boundary_of_0 = 0
        left_boundary_of_2 = len(nums) - 1
        i = 0
        while i <= left_boundary_of_2:
            if nums[i] == 0:
                middleValue = nums[right_boundary_of_0]
                nums[right_boundary_of_0] = 0
                nums[i] = middleValue
                right_boundary_of_0+=1              ******************1
                i+=1                       ******************1
            elif nums[i] == 2:
                middleValue = nums[left_boundary_of_2]
                nums[left_boundary_of_2] = nums[i]
                nums[i] = middleValue
                left_boundary_of_2 -=1
            else:
                i+=1
            print(i,right_boundary_of_0,left_boundary_of_2,nums)

 

 

解决原地问题的思路:

  1.三指针,0的有边界,2的左边界,当前遍历值,while cur <= right_boundary_of_2:

   2.代码中标记的两行,只有在与左边0呼唤之后,才会 i++ ,因为换过去的是0,就达到了把0放在左边的目的。

    其实这里我还是没想太明白,以后再想把

75. 颜色分类 leetcode

标签:颜色   return   color   技术   元素   整数   ret   sel   红色   

原文地址:https://www.cnblogs.com/ChevisZhang/p/12436447.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!