【剑斩OFFER】算法的暴力美学——颜色分类

一、题目描述

二、算法原理

由题目可知,我们可以把一个数组(无论是什么数组最终的情况)里面的情况分成:

故而,我们可以使用分治的思想来解决这道题:

可以把这个数组分成四个部分:

【0,left】:等于0

【left+1,i -1】:等于1

【i,right - 1】:未知数字(待扫描)

【right,nums.size() -1】:等于2

根据上面这四个部分可以制定处理方法:

当 nums[ i ] == 0 时,swap(nums[ i++ ] ,nums[ ++left ] );

当 nums[ i ] == 1 时,i++

当 nums[ i ] == 2 时,swap(nums[ i ],nums[ -- right] ),注意:这里的 i 是不能 ++ 的,因为当他们交换时,nums[ i ] 是一个未扫描的数字,所以我们要再扫描一次。

当然一开始 left = -1,i = 0,right = nums.size(),因为我们还没有开始处理数据。

三、代码实现

cpp 复制代码
class Solution {
public:
    void sortColors(vector<int>& nums) {
        int i = 0;
        int left = -1,right = nums.size();
        while(i < right)
        {
            if(nums[i] == 0) swap(nums[i],nums[++left]);
            else if(nums[i] == 2)
            {
                swap(nums[i],nums[--right]);
                continue;//再次扫描未知数据
            }
            i++;
        }
    }
};
相关推荐
橙汁味的风4 小时前
2EM算法详解
人工智能·算法·机器学习
维构lbs智能定位4 小时前
北斗卫星导航定位从核心框架到定位流程详解(一)
算法·北斗卫星导航定位系统
byzh_rc4 小时前
[算法设计与分析-从入门到入土] 动态规划
算法·动态规划
Halo_tjn4 小时前
Java List集合知识点
java·开发语言·windows·算法·list
CC.GG4 小时前
【C++】哈希表的实现
java·c++·散列表
云飞云共享云桌面5 小时前
河北某机器人工厂8个研发设计共享一台SolidWorks云主机
运维·服务器·网络·数据库·算法·性能优化·机器人
元亓亓亓5 小时前
LeetCode热题100--152. 乘积最大子数组--中等
算法·leetcode·职场和发展
bkspiderx5 小时前
C++变量生命周期:从创建到销毁的完整旅程
c++·生命周期·作用域·变量生命周期
执笔论英雄5 小时前
【RL】Slime训练流程
算法
梭七y6 小时前
【力扣hot100题】(103)移动零
数据结构·算法·leetcode