欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

颜色分类

程序员文章站 2022-04-24 14:12:55
...

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

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

注意:
不能使用代码库中的排序函数来解决这道题。

示例:

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

其主要思想是给每个数字设定一种颜色
颜色分类
我们用三个指针(p0, p2 和curr)来分别追踪0的最右边界,2的最左边界和当前考虑的元素。

颜色分类
本解法的思路是沿着数组移动 curr 指针,若nums[curr] = 0,则将其与 nums[p0]互换;若 nums[curr] = 2 ,则与 nums[p2]互换。

算法

  • 初始化0的最右边界:p0 = 0。在整个算法执行过程中 nums[idx < p0] = 0.
  • 初始化2的最左边界 :p2 = n - 1。在整个算法执行过程中 nums[idx > p2] = 2.
  • 初始化当前考虑的元素序号 :curr = 0.
  • While curr <= p2 :
    若 nums[curr] = 0 :交换第 curr个 和 第p0个 元素,并将指针都向右移。
    若 nums[curr] = 2 :交换第 curr个和第 p2个元素,并将 p2指针左移 。
    若 nums[curr] = 1 :将指针curr右移。

实现
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
颜色分类
代码

class Solution {
  /*
  荷兰三色旗问题解
  */
  public void sortColors(int[] nums) {
    // 对于所有 idx < i : nums[idx < i] = 0
    // j是当前考虑元素的下标
    int p0 = 0, curr = 0;
    // 对于所有 idx > k : nums[idx > k] = 2
    int p2 = nums.length - 1;

    int tmp;
    while (curr <= p2) {
      if (nums[curr] == 0) {
        // 交换第 p0个和第curr个元素
        // i++,j++
        tmp = nums[p0];
        nums[p0++] = nums[curr];
        nums[curr++] = tmp;
      }
      else if (nums[curr] == 2) {
        // 交换第k个和第curr个元素
        // p2--
        tmp = nums[curr];
        nums[curr] = nums[p2];
        nums[p2--] = tmp;
      }
      else curr++;
    }
  }
}
相关标签: 算法题库