leetcode 颜色分类_leetcode72

leetcode 颜色分类_leetcode72给定一个包含红色、白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色、白色、蓝色顺序排列。此题中,我们使用整数 0、 1 和 2 分别表示红色、白色和蓝色。示例 1:输入:nums = [2,0,2,1,1,0]输出:[0,0,1,1,2,2]示例 2:输入:nums = [2,0,1]输出:[0,1,2]示例 3:输入:nums = [0]输出:[0]示例 4:输入:nums = [1]输出:[1] 提示:n == num

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

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

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

示例 1:

输入:nums = [2,0,2,1,1,0]
输出:[0,0,1,1,2,2]
示例 2:

输入:nums = [2,0,1]
输出:[0,1,2]
示例 3:

输入:nums = [0]
输出:[0]
示例 4:

输入:nums = [1]
输出:[1]
 

提示:

n == nums.length
1 <= n <= 300
nums[i] 为 0、1 或 2
 

进阶:

你可以不使用代码库中的排序函数来解决这道题吗?
你能想出一个仅使用常数空间的一趟扫描算法吗?

题解

  1. 快排
class Solution { 
   
public:
    void quick(int l,int r,vector<int>& nums){ 
   
        if(l < r){ 
   
            int mid = partion(l,r,nums);
            quick(l,mid - 1,nums);
            quick(mid + 1,r,nums);
        }
    }
    int partion(int l,int r,vector<int>&nums){ 
   
        int key = nums[l];
        while(l < r){ 
   
            while(l < r && nums[r] > key)r --;
            if(l < r)nums[l ++] = nums[r];
            while(l < r && nums[l] < key)l ++;
            if(l < r)nums[r --] = nums[l];
        }
        nums[l] = key;
        return l;
    }
    void sortColors(vector<int>& nums) { 
   
        int l = 0,r = nums.size() - 1;
        quick(l,r,nums);
    }
};
  1. 因为只有3组数字,最左边有一组,最右边有一组,中间有一组,所以把最左边和最右边都规整后,中间自然就规整,所以设置i,j代表左边放置0的下边,j为右边放置2的下标.

时间复杂度O(n)

class Solution { 
   
public:
    void sortColors(vector<int>& nums) { 
   
        int i = 0,n = nums.size(),j = nums.size() - 1;
        while(i < n && nums[i] == 0)i ++;
        while(j >= 0 && nums[j] == 2)j --;
        for(int k = i;k <= j;k ++){ 
   
            if(nums[k] == 0)swap(nums[i],nums[k]),i ++;
            else if(nums[k] == 2)swap(nums[j],nums[k]),k --,j --;   //注意当从后面换回去的时候可能回把后面的0换到前面
        }
    }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168710.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 下午4:16
下一篇 2022年8月8日 下午4:16


相关推荐

  • 手机浏览器上网谁最快?手机浏览器速度测评

    手机浏览器上网谁最快?手机浏览器速度测评目前手机端浏览器用户不断成熟 而且现在用户的需求逐渐从分数 排名 功能等发展到浏览器自身的性能 根据 CNNIC 的统计报告 现在 74 5 的网民选择手机浏览器最重要的因素是速度 大量的手机浏览器让用户眼花缭乱 那么手机浏览器上网谁最快

    2026年3月17日
    2
  • Ubuntu安装和卸载CUDA和CUDNN[通俗易懂]

    Ubuntu安装和卸载CUDA和CUDNN[通俗易懂]目录目录前言卸载CUDA安装CUDA下载和安装CUDA下载和安装CUDNN测试安装结果参考资料前言最近在学习PaddlePaddle在各个显卡驱动版本的安装和使用,所以同时也学习如何在Ubuntu安装和卸载CUDA和CUDNN,在学习过程中,顺便记录学习过程。在供大家学习的同时,也在加强自己的记忆。卸载CUDA为什么一开始我就要卸载CUDA…

    2022年6月12日
    31
  • Python:列表 【全用法】

    Python:列表 【全用法】python 中有列表 元组 集合 字典这四种可以存放多个数据元素的集合 他们在总体功能上都起着存放数据的作用 却都有着各自的特点 本片文章中我们会对列表的用法做详细说明 演示环境 python3 6pycharm 中的 python3 6 第一部分 列表 list 列表 list 用来存储不同的数据类型 使用 例如 service http ssh ftp

    2026年3月16日
    3
  • SparkSQL(一)

    SparkSQL(一)简介 spark1 0 版本就已经退出 SparkSQL 最早叫 sharkShark 是基于 spark 框架并且兼容 hive 执行 SQL 执行引擎 因为底层使用了 Spark 比 MR 的 Hive 普遍要快上两倍左右 当数据全部 load 到内存中 此时会比 Hive 快上 10 倍以上 SparkSQL 就是一种交互式查询应用服务特点 1 内存列存储 可以大大优化内存的使用率 减少内存消耗 避免 GC 对大量数据性能的开销 2

    2026年3月16日
    3
  • Midjourney关键词格式案例 Midjourney关键词权重

    Midjourney关键词格式案例 Midjourney关键词权重

    2026年3月15日
    1
  • java分页计算公式_java将list分页

    java分页计算公式_java将list分页1根据传入的参数计算1.1请求参数(currPage:当前页、pageSize:每页展示条数),根据这两个参数计算起始起始条数、截止条数 起始条数 firstIndex=(currPage-1)*pageSize 截止条数 lastIndex=currPage*pageSize1.2计算总页码(需获取总条数)pages=total%pageSize==0?total/pageSize:total/pageSize+1…

    2022年10月3日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号