当前位置: 首页 > wzjs >正文

广东建设网站公司南昌为来创意网站建设公司

广东建设网站公司,南昌为来创意网站建设公司,谷歌搜索优化seo,网站备案简单吗1. 题目链接 LeetCode 75. 颜色分类 2. 题目描述 给定一个包含红色(0)、白色(1)和蓝色(2)的数组 nums,要求原地对数组进行排序,使得相同颜色的元素相邻,且按红、白、蓝…
1. 题目链接

LeetCode 75. 颜色分类


2. 题目描述

给定一个包含红色(0)、白色(1)和蓝色(2)的数组 nums,要求原地对数组进行排序,使得相同颜色的元素相邻,且按红、白、蓝顺序排列。
要求

  • 仅使用常数空间。
  • 仅遍历数组一次。

示例

  • 输入:nums = [2,0,2,1,1,0] → 输出:[0,0,1,1,2,2]
  • 输入:nums = [2,2,1,0] → 输出:[0,1,2,2]

3. 示例分析
  1. 常规案例
    • 输入:[2,0,2,1,1,0]
      • 通过交换将 0 移动到左侧,2 移动到右侧,中间保留 1
      • 最终结果:[0,0,1,1,2,2]
  2. 边界案例
    • 输入全为 0[0,0,0] → 无需操作,直接返回。
    • 输入全为 2[2,2,2] → 所有元素交换到右侧。
    • 输入全为 1[1,1,1] → 无需操作。

4. 算法思路

核心思想三指针法

  1. 指针定义
    • left:指向已处理 0 的右边界(初始为 -1)。
    • right:指向已处理 2 的左边界(初始为 n)。
    • i:遍历指针,从 0 开始。
  2. 遍历规则
    • nums[i] == 0
      • 交换 nums[++left]nums[i]i++
      • 0 移动到 left 右侧,扩展 0 的区域。
    • nums[i] == 1
      • i++
      • 1 保留在中间区域,无需处理。
    • nums[i] == 2
      • 交换 nums[--right]nums[i]
      • 2 移动到 right 左侧,扩展 2 的区域。
      • 不移动 i:交换后的 nums[i] 可能是 01,需再次检查。
  3. 终止条件
    • i >= right 时,所有元素已处理完毕。

5. 边界条件与注意事项
  1. 0/1/2 数组
    • 01:遍历后指针无需移动,直接返回。
    • 2i 不移动,通过交换将所有元素移动到右侧。
  2. 单元素数组
    • 无需操作,直接返回。
  3. 元素交换顺序
    • 交换 2 时,i 不自增,确保新元素被检查。
  4. 时间复杂度
    • 每个元素最多被交换两次,时间复杂度为 O(n)

6. 代码实现
class Solution {
public:void sortColors(vector<int>& nums) {int n = nums.size();int left = -1, right = n, i = 0;while (i < right) {if (nums[i] == 0) {swap(nums[++left], nums[i++]); // 交换0到左区,i前进} else if (nums[i] == 1) {i++; // 保留中间区} else {swap(nums[--right], nums[i]); // 交换2到右区,i不前进}}}
};

在这里插入图片描述


关键步骤解析

  1. 初始化指针

    int left = -1, right = n, i = 0;
    
    • left 初始指向 0 区的左边界(无元素),right 指向 2 区的右边界。
  2. 处理 0 的逻辑

    swap(nums[++left], nums[i++]);
    
    • left 向右扩展,将 0 交换到 0 区末尾,i 前进。
  3. 处理 2 的逻辑

    swap(nums[--right], nums[i]);
    
    • right 向左扩展,将 2 交换到 2 区头部,i 不前进

与其他解法的对比

方法时间复杂度空间复杂度核心思想
三指针法O(n)O(1)分区交换,一次遍历
计数排序法O(n)O(1)统计频次,重新填充数组
双指针法O(n)O(1)两次遍历,先排0再排1

总结

三指针法通过一次遍历实现原地排序,是解决荷兰国旗问题的经典方案。其核心在于 分区处理指针动态调整,以线性时间高效完成排序。

优化点

  • 合并部分条件判断,减少代码行数。
  • 预判全 1 情况,提前终止遍历。

适用场景

  • 需要严格满足“一次遍历”和“常数空间”要求的场景。
  • 大规模数据排序(n ≤ 1e5)。

关键点

  • 理解 iright 的协作逻辑。
  • 处理 02 时的指针移动差异。
http://www.dtcms.com/wzjs/837580.html

相关文章:

  • 南宫建设局网站首页wordpress ajax主题
  • 手机版免费申请微网站html网页基础代码
  • 怎么吧自己电脑做网站夸克网站免费进入
  • 宠物网站制作内容wordpress 分类 文章数
  • 没有网站可以做京东联盟吗设计头条
  • 有哪些做ppt用图片的网站html下载安装
  • 中商外贸网站合肥工程建设信息网站
  • 电子政务网站建设ppt建立网站主机
  • 怎么自己建立网站wordpress 用户后台
  • 网站被管理员权限合肥建设网站首页
  • 网站建设供需国外的域名注册网站哪个好
  • 怎样为公司做网站网页设计的论文怎么写
  • 清溪东莞网站建设wordpress模板外贸
  • html公益网站模板阿里巴巴的网站怎么做的
  • 做百度ssp的网站开发人用.net做网站
  • 魔方网站导航设计seo推广公司网站模板
  • 凡科建站源码广州网页设计模板
  • 小型网站开发怎样推广自己的项目
  • 设计网页的快捷网站网站改版介绍
  • 个人博客网站建设选题说明河南省财政企业信息管理系统
  • 网络销售型网站有哪些网络营销推广渠道
  • 北京托管网站地方网站盈利模式
  • 营销网站模板html自己切片视频做网站
  • 新手学做网站要花钱么如何做亚马逊跨境电商
  • 黑白灰 网站国际网页浏览器
  • 出售企业网站备案资料中国创业网
  • php网站源代码修改静态网站有哪些优点
  • 如何提高网站的知名度教育机构网站模板
  • 制作专业网站全球外贸网
  • 献县做网站在线识别图片