【每天学习一点算法 2026/03/21】颜色分类

每天学习一点算法 2026/03/21

题目:颜色分类

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

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

必须在不使用库内置的 sort 函数的情况下解决这个问题。

常规的排序算法我这里就不多讲了,我的另一篇文章 前端算法基础 里面有写 (包括冒泡、选择、插入、快速)。

因为这个数组里面只有三种元素,所以我们可以采用一些比较,特殊的方法:简单的说就是 1 放中间 0 和 2 放两边。

typescript 复制代码
/**
 Do not return anything, modify nums in-place instead.
 */
function sortColors(nums: number[]): void {
  if (nums.length < 2) return // 只有一项不用排序
  let whiteStart = 0 // 白色插入位置
  const res: number[]  = [] // 存放排序后数组
  for (let i = 0; i < nums.length; i++) {
    if (nums[i] === 0) {
      // 0 放在前面,白色插入位置后移
      res.unshift(0)
      whiteStart++
      continue
    }
    if (nums[i] === 1) {
    	// 1 直接在 whiteStart 处插入
      res.splice(whiteStart, 0, 1)
      continue
    }
    if (nums[i] === 2) {
      // 2 直接放在最后
      res.push(2)
      continue
    }
  }
	// 修改元素
  res.forEach((item, index) => {
    nums[index] = item
  })
};

但是这个不是纯粹的原地排序,我们可以在这个基础上调整一下,因为我们移动 2 的时候遍历指针需要停在原地,所以需要一个 count 来辅助遍历。

typescript 复制代码
function sortColors(nums: number[]): void {
  if (nums.length < 2) return
  let count = nums.length // count 初始为数组长度
  for (let i = 0; i < count; i++) {
    if (nums[i] === 0) {
      // 0 取出来放在前面
      // 虽然取出了一项,但是放在前面了所以不用处理
      nums.splice(i, 1)
      nums.unshift(0)
      continue
    }
    if (nums[i] === 1) {
      // 1 直接不处理
      continue
    }
    if (nums[i] === 2) {
      // 2 取出来放在后面
      nums.splice(i, 1)
      nums.push(2)
      // 指针不动,遍历边界减 1,防止重复遍历 push 的 2
      i--
      count--
      continue
    }
  }
};

题目来源:力扣(LeetCode)

相关推荐
Dillon Dong2 小时前
【风电控制】TI TMS320F28379D 双CPU架构解析与任务分布设计
嵌入式硬件·算法·变流器·风电控制
一尘之中7 小时前
从C语言底层设计到系统架构评估:软件架构知识体系全景
学习·系统架构·ai写作
小羊在睡觉7 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary7 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记7 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466857 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
_日拱一卒8 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
星夜夏空998 小时前
FreeRTOS学习(4)——内存映射
数据库·学习·mongodb
珂朵莉MM8 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
不羁的木木8 小时前
ArkWeb实战学习笔记05-综合实战:构建混合应用
笔记·学习·harmonyos