75.颜色分类


原地排序:空间复杂度为1

cpp 复制代码
class Solution {
public:
    void sortColors(vector<int>& nums) {
        if(0){
            //法一:单指针两个遍历
            int n=nums.size();
            int ptr=0;
            for(int i=0;i<n;i++){
                if(nums[i]==0){
                    swap(nums[i],nums[ptr]);
                    ++ptr;
                }
            }
            for(int i=ptr;i<n;i++){
                if(nums[i]==1){
                    swap(nums[i],nums[ptr]);
                    ++ptr;
                }
            }
        }else if(1){
            //双指针法
            int n=nums.size();
            int p0=0,p2=n-1;
            int i=0;
            while(i<=p2){
                if(nums[i]==0){
                    swap(nums[i],nums[p0]);
                    ++p0;
                    ++i;
                }else if(nums[i]==1){
                    ++i;
                }else{
                    swap(nums[i],nums[p2]);
                    --p2;
                }
            } 
        }
        return;
    }
};
相关推荐
千金裘换酒1 天前
Leetcode 二叉树中序遍历 前序遍历 后序遍历(递归)
算法·leetcode·职场和发展
cookqq1 天前
MySQL 5.7 大表删除部分数据:.ibd 文件会变小吗?磁盘会释放吗?
数据结构·数据库·mysql
姓蔡小朋友1 天前
算法-双指针
算法
D_FW1 天前
数据结构第三章:栈、队列与数组
数据结构·算法
福楠1 天前
模拟实现stack、queue、priority_queue
c语言·开发语言·数据结构·c++
Tisfy1 天前
LeetCode 1339.分裂二叉树的最大乘积:深度优先搜索(一次DFS+存数组并遍历)
算法·leetcode·深度优先·题解
csdn_aspnet1 天前
MATLAB 高效算法实战:数据分析与算法优化的效率秘诀
算法·matlab·数据分析
budingxiaomoli1 天前
优选算法--链表
数据结构·算法·链表
漫随流水1 天前
leetcode算法(637.二叉树的层平均值)
数据结构·算法·leetcode·二叉树
漫随流水1 天前
leetcode算法(102.二叉树的层序遍历)
数据结构·算法·leetcode·二叉树