LeetCode 75 Sort Colors 颜色分类(荷兰国旗)

简介: Given an array with n objects colored red, white or blue, sort them in-place so that objects of the same color are adjacent, with the colors in the order red, white and blue.Here, we will use the integers 0, 1, and 2 to represent the color red, white, and blue respectively.

Given an array with n objects colored red, white or blue, sort them in-place so that objects of the same color are adjacent, with the colors in the order red, white and blue.


Here, we will use the integers 0, 1, and 2 to represent the color red, white, and blue respectively.


Note: You are not suppose to use the library's sort function for this problem.


Example:


Input: [2,0,2,1,1,0]

Output: [0,0,1,1,2,2]

Follow up:


A rather straight forward solution is a two-pass algorithm using counting sort.

First, iterate the array counting number of 0's, 1's, and 2's, then overwrite array with total number of 0's, then 1's and followed by 2's.

Could you come up with a one-pass algorithm using only constant space?


解法1:

类似于:多名员工排序问题:http://blog.sina.com.cn/s/blog_13c6397540102wzv8.html


计数排序(区分桶排序)


两次循环


class Solution {

public:

   void sortColors(vector<int>& nums)

   {

        int count[3] = {0}, idx = 0;

         for (int i = 0; i < nums.size(); ++i)

             ++count[nums[i]];

         for (int i = 0; i < 3; ++i)

         {

             for (int j = 0; j < count[i]; ++j)

             {

               nums[idx++] = i;

            }

       }

   }

};


解法2:

双指针实现


遍历一次数组。用两个指针分别指向首尾。遍历一次数组,遇到0时,将0向前搬移,遇到2时,向后搬移


class Solution {

public:

   void sortColors(vector<int>& nums)

   {

     int left =0,right=nums.size()-1;

       for(int i=0;i<=right;++i)

       {

           if(nums[i]==0)

               swap(nums[left++],nums[i]);

           else if(nums[i]==2)

               swap(nums[right--],nums[i--]);

       }

   }

};

参考:https://blog.csdn.net/qq_43387999/article/details/86982438


解法3:


3路快速排序区分2路快排(普通快排),针对数组中有重复时。


快速排序的优化:https://www.cnblogs.com/2390624885a/p/7067669.html


class Solution {

public:

   void sortColors(vector<int>& nums)

   {

    if(nums.empty())

           return;

       int zero = -1;          //[0,zero]元素为1

       int two = nums.size();  //[two,nums.size() - 1]元素为2

       for(int i = 0; i < two; )

       {

           if(nums[i] == 1)

               ++i;

           else if(nums[i] == 0)

               swap(nums[++zero],nums[i++]);

           else if(nums[i] == 2)

               swap(nums[--two],nums[i]);

       }

   }

};

另一种写法:


/*

由于只有012 三个数为此选择1作为基准v

而通用的基准往往是放在第一个位置,并从第二个位置开始,所以结束后最后还要将基准v放到合适的位置

*/

class Solution {

public:

   void sortColors(vector<int>& nums)

   {

    if(nums.empty())

           return;

       int i = 0;  // nums[0..<i) == 0

       int j = 0;  // nums[i..<j) == 1

       int k = nums.size(); // nums[k..<n) == 2

      //分为3步走

       while( j < k )//j表示当前元素所在的位置

       {

           if( nums[j] == 1 )

               j++;

           else if( nums[j] == 0 )

               swap( nums[i++] , nums[j++] );

           else{ // nums[j] == 2

               assert( nums[j] == 2 );//断言判断是否为2

               swap( nums[j] , nums[k-1] );

               k --;

           }

       }

       return;

   }

};

目录
相关文章
|
5月前
|
算法 搜索推荐
LeetCode第75题颜色分类
文章介绍了LeetCode第75题"颜色分类"的解法,通过双指针技术对数组中的0、1和2进行排序,避免了传统的排序算法,提供了一种时间复杂度为O(n)的高效解决方案。
LeetCode第75题颜色分类
|
5月前
|
算法 Python
【Leetcode刷题Python】 LeetCode 2038. 如果相邻两个颜色均相同则删除当前颜色
本文介绍了LeetCode 2038题的解法,题目要求在一个由'A'和'B'组成的字符串中,按照特定规则轮流删除颜色片段,判断Alice是否能够获胜,并提供了Python的实现代码。
60 3
|
5月前
|
Python
【Leetcode刷题Python】75. 颜色分类
在不使用sort函数的情况下对包含红色、白色和蓝色元素的数组进行排序的方法:插入排序法和单指针交换法,并提供了相应的Python实现代码。
23 0
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
【经典LeetCode算法题目专栏分类】【第9期】深度优先搜索DFS与并查集:括号生成、岛屿问题、扫雷游戏
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第8期】滑动窗口:最小覆盖子串、字符串排列、找所有字母异位词、 最长无重复子串
【经典LeetCode算法题目专栏分类】【第8期】滑动窗口:最小覆盖子串、字符串排列、找所有字母异位词、 最长无重复子串
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
【经典LeetCode算法题目专栏分类】【第7期】快慢指针与链表
|
7月前
|
算法
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
|
7月前
|
算法 机器人
【经典LeetCode算法题目专栏分类】【第5期】贪心算法:分发饼干、跳跃游戏、模拟行走机器人
【经典LeetCode算法题目专栏分类】【第5期】贪心算法:分发饼干、跳跃游戏、模拟行走机器人