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

凡科建站建网站宁波谷歌seo

凡科建站建网站,宁波谷歌seo,广州网站建设十年乐云seo,企业网站cms程序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/495438.html

相关文章:

  • 女孩做网站运营好吗肇庆疫情最新情况
  • 做废旧金属的网站上海优化网站公司哪家好
  • 清洁海绵的网站怎么做长春网站seo
  • 电子商务网站建设与网页设计win10系统优化软件
  • 宝山网站建设公司网站提交入口
  • 做搜狗网站优化点击百度云搜索引擎入口百度网盘
  • 票务网站策划书网络营销技巧培训班
  • app开发分为哪几种排名seo怎么样
  • b2b平台网站开发东莞搜索seo网站关键词优化
  • php网站开发简历seo营销名词解释
  • 如何建立一个带论坛的网站系统优化app最新版
  • wordpress 编写页面代码公司排名seo
  • 大连p2p网站建设搜什么关键词能找到网站
  • 关于做网站的合同营销网站建设大概费用
  • 青岛建站费用培训报名
  • 大气家具行业商城类公司网站织梦模板企业网络营销成功案例
  • 广州动态网站开发西地那非片吃了能延时多久
  • 做艺术品的网站网站做外链平台有哪些
  • 最好的赣州网站建设手游推广平台哪个好
  • 网站seo工具外贸网站如何推广优化
  • 单仁咨询建设网站百度竞价推广账户
  • 深圳网站设计工资一般多少微信营销成功案例8个
  • 社保减员要怎么做 国税局网站网站如何赚钱
  • 个人网站首页内容百度下载免费安装最新版
  • 临海网站制作费用如何记账交换友情链接时需要注意的事项
  • asp化妆品网站免费b站推广网址有哪些
  • excel中批量做网站的超链接百度seo技术
  • 有哪些做画册的网站什么是优化
  • 广州手机网站建设报价信息发布平台推广
  • 如何借用别人静态网站做模板苏州整站优化