[Leetcode刷题] - LC075 Sort Colors

news2025/1/13 7:30:54

题目描述

一个随机序列包含0,1,2 在不占用额外内存的情况下将序列排序。

题目思路

1. 计数排序

计数排序思路比较简单,记录三个数字出现频率,然后根据频率将0,1,2重新加入数组,思路较为简单。

class Solution {
    public void sortColors(int[] nums) {
        // count sort
        int red = 0;
        int white = 0;
        int blue = 0;

        for (int i: nums) {
            if (i==0) red++;
            else if (i==2) blue++;
            else white++;
        }

        for (int i=0; i<nums.length; i++) {
            if (red!=0) {
                nums[i]=0;
                red--;
            } else if (white!=0) {
                nums[i]=1;
                white--;
            } else {
                nums[i]=2;
                blue--;
            }
        }


    }
}

时间复杂度:O(2N), 需要遍历两遍;空间复杂度:O(1)。 

2. 对向双指针 + 遍历指针

思路类似快速排序的partition算法,主要需要明确指针遍历时循环不变量,本题循环不变量可以定义为如下:(参考力扣)

循环不变量

定义p0 = 数字0的右边界,p1 = 数字1的右边界,p2 = 数字2的左边界

1. [0, p0) - 左闭右开区间内所有数字 == 0

2. [p0, p1) - 左闭右开区间所有数字 == 1

3. (p2, end] - 左开右闭区间内所有数字 == 2

引用: https://leetcode.cn/problems/sort-colors/solution/yan-se-fen-lei-by-leetcode-solution/

 根据上述循环不变量条件,定义一个三个指针p0, p1, p2 来记录0,1,2的边界,我们可以验证一下这个循环不变量的正确性。

1. 初始时,p0=0, p1=0, p2=nums.length-1, 三个区间内没有值

2. 移动 p1 指针,如果[p0, p1]区间内发现 2,将p1 和 p2的值交换,这样[p2, end]依然满足都是2,可以将p2向左移动一步,但是[p0, p1]经过交换后并不确定是否是1,所以不能移动p1,要在下一次循环中检验

3. 同理,移动 p1 指针,如果[p0, p1]区间内发现 0,将p1 和 p0的值交换,这样[0, p0]依然满足都是0,可以将p0向右移动一步

4. 如果 p1 指针当前值是 1,那么证明[p0, p1]这部分依然满足都是1,p1向右移动一步

代码如下:

class Solution {
    public void sortColors(int[] nums) {
        int p0 = 0;
        int p2 = nums.length-1;
        int p1=0;

        while(p1<nums.length) {
            if (p1<p2 && nums[p1]==2) {
                // if [p0, i] has 2 inside then move 2 to [p2, end]
                // since after swap, nums[p2] is 2, move p2 to p2-1 then check
                // since new nums[i] unknown need to check in next loop
                swap(nums, p1, p2);
                p2--;
            } else if (p1>=p0 && nums[p1]==0) {
                // if [p0, i] has 0 inside then move 0 to [0, p0]
                // after then nums[p0] is 0, move p0 to p0+1 then check
                // since new nums[i] unknown need to check in next loop
                swap(nums, p1, p0);
                p0++;
            } else {
                // if [p0, i] is 1, match move to next one
                p1++;
            }
        }
        
    }
        
    private void swap(int[] nums, int a, int b) {
        int temp = nums[a];
        nums[a] = nums[b];
        nums[b] = temp;
    }
} 

 时间复杂度:O(N);空间复杂度:O(1)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/547477.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【数据结构】--单链表力扣面试题④找链表中倒数第k个结点

目录 法一、遍历链表法 法二、快慢指针法 题述&#xff1a;输入一个链表&#xff0c;输出该链表中倒数第k个结点 示例&#xff1a; 输入:1,[1,2,3,4,5] 返回值:[5] 已知链表的定义和函数头FindKthToTail&#xff0c;让你完善FindKthToTail函数 struct ListNode { int…

基于html+css的图展示81

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

探索Vue的组件世界-组件复用

目录 Mixin【混入】 缺陷 HOC&#xff08;higher order component&#xff09;【高阶组件】 相比较Mixin的优点&#xff1a; 不足&#xff1a; Renderless组件【函数式组件&#xff0c;无渲染组件&#xff0c;Vue社区使用比较多的一种业务复用模式】 优点&#xff1a; M…

网上书城系统的设计与实现

背景 设计一个网上书城管理系统&#xff0c;通过这个系统能够满足网上书城的管理及用户的图书信息管理及购物功能。系统的主要功能包括&#xff1a;首页、个人中心、用户管理、图书类型管理、图书分类管理、图书信息管理、我的收藏管理、系统管理、订单管理等功能。 管理员可…

5号与25号发工资的差别这么大?我居然才知道(文末附招聘岗位)

可能是新一轮的毕业季马上就来了&#xff0c;最近热搜上出现了很多关于工作&#xff0c;收入与存款的热点。诸如#年入20万是什么水平# …… 前面的话题小编已经在上篇文章说过了&#xff0c;感兴趣的朋友可以点击这里围观↓↓↓ 『在中国&#xff0c;年收入20W是什么水平&am…

【音视频开发】常用工具软件

软件名描述MediaInfo分析视频文件VLC播放器播放测试EasyICE分析TS流flyAnalyser分析FLV格式的视频文件mp4box分析MP4格式的视频文件Audacity分析音频PCM文件Elecard_streamEye分析H.264海康YUVPlayer分析YUV

【Android入门到项目实战-- 11.2】—— 实现底部导航栏(RadioGroup+Fragment)

实现效果 效果如下&#xff0c;使用RadioGroup实现&#xff0c;不能左右滑动切换页面&#xff0c;适用于导航页里还有需要切换页面的场景&#xff0c;如果需要滑动效果&#xff0c;使用ViewPager实现。 准备工作 以下示例按照图上实现&#xff0c;具体多少个页面&#xff0c;按…

【C++刷题集】-- day2

目录 选择题 单选 编程题 OR62 倒置字符串⭐ 【题目解析】 【解题思路1】 【解题思路2】 【解题思路3】 排序子序列⭐ 【题目解析】 【解题思路】 选择题 单选 1、使用printf函数打印一个double类型的数据&#xff0c;要求&#xff1a;输出为10进制&#xff0c;输…

儿童教育软件推荐

1、出口算题系统 胡迪数学运算练习 2、迪乐姆是上海和盛实业集团有限公司注册的教育品牌&#xff0c;涵盖人工智能、科学、艺术、运动、创造力等多元教育领域&#xff0c;提供自主知识产权的全套课程产品、师资培养体系、环境创设实施等一站式素质教育个性化服务。 [1] 截止到…

【Proteus仿真】51单片机串口输出实验

【Proteus仿真】51单片机串口输出实验 &#x1f4cc;相关篇《【Proteus仿真】51单片机Blink点灯实验》&#x1f516;Proteus仿真基础实验-串口输出。&#x1f33f;Proteus8.12平台&#x1f33f;本实验代码基于VSM Studio&#xff0c;采用SDCC编译器。&#x1f33f;调试串口波特…

计算机图形学-GAMES101-12阴影

Shadow mapping 问题的提出 我们之前在进行着色时&#xff0c;对于每个物体仅考虑自己&#xff0c;而不考虑其他物体对它的影响。限定在光栅化中&#xff0c;如何解决阴影问题呢&#xff1f;阴影能被摄像机看到&#xff0c;但不能被光源所照亮。经典的Shadow mapping只能处理…

POSTGRESQL EDB 企业版 PG 15 独有功能

开头还是介绍一下群&#xff0c;如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;CTO&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;在新加的朋友会分到2群&#xff08;共…

基于SpringBoot的人事管理系统的设计与实现

背景 人事管理管理方面的任务繁琐,以至于公司每年都在人事管理这方面投入较多的精力却效果甚微,人事管理系统的目标就是为了能够缓解人事管理工作方面面临的压力,让人事管理方面的工作变得更加高效准确。 系统架构 考虑到实际生活中在人事管理方面的需要以及对该系统认真的分…

由浅入深Netty粘包与半包解决方案

目录 1 粘包现象2 半包现象3 现象分析4 解决方案4.1 方法1&#xff1a;短链接4.2&#xff1a;方法2&#xff1a;固定长度4.3 方法3&#xff1a;固定分隔符4.4 方法4&#xff1a;预设长度 1 粘包现象 服务端代码 public class HelloWorldServer {static final Logger log Logg…

ARM的基本数据处理指令与条件代码的使用

最开始在此介绍一下CPSR寄存器中 N、Z、C、V 4位的作用&#xff1a; Bit[28]&#xff08;V&#xff09;&#xff1a; 当运算器中进行加法运算且产生符号位进位时该位自动置1&#xff0c;否则为0 当运算器中进行减法运算且产生符号位借位时该位自动置0&#xff0c;否则为1 …

js 多个小程序之间互相跳转,a小程序带参跳转到b小程序中

小程序中实现两个或者多个小程序之间互相跳转&#xff0c;a小程序带参跳转到b小程序中。 官方入口&#xff1a;wx.navigateToMiniProgram(Object object) https://developers.weixin.qq.com/miniprogram/dev/api/navigate/wx.navigateToMiniProgram.html 实现步骤&#xff1a; …

English Learning - L3 综合练习 3 VOA-Food 2023.05.17 周三

English Learning - L3 综合练习 3 VOA-Food 2023.05.17 周三 句 1句 2句 3句 4句 5句 6句 7句 8句 9句 10句 11句 12句 13句 14句 15结尾&#xff1a;注意力和记忆力&#xff0c;都是需要开垦的 句 1 注意后面的介词短语是当定语的 我们提供更多有关食物的表达。 they are f…

21 排序

文章目录 排序排序的基本概念排序方法的分类 插入排序直接插入排序性能分析代码实现 折半插入排序性能分析代码实现 希尔排序性能分析代码实现 交换排序冒泡排序分析和改进拓展&#xff08;提高冒泡效率的方法&#xff09;短路冒泡代码实现双向冒泡法&#xff08;鸡尾酒排序&am…

跟着NC学cfDNA全基因组片段化丰度谱分析

继续我们的跟着NC学系列&#xff0c;前面分享的是关于16S扩增子测序和宏基因组数据分析的。考虑到我们有许多小伙伴是做人类基因组方面的&#xff0c;这次分享一篇癌症早筛方面的&#xff0c;血液DELFI全基因组片段化丰度谱检测的分析框架。题目是&#xff1a;Detection and ch…

Fast-RCNN网络详解

文章目录 一、前言二、Fast-RCNN原理步骤2.1候选区域的生成2.2.ROI Pooling层2.3.分类器2.4.边界框的预测2.5.损失计算2.5.1.分类损失2.5.2.边界框回归损失 三、总结参考博客与视频、代码 一、前言 前面学习了SS算法、R-CNN网络&#xff0c;接下来继续学习Fast-RCNN网络。 本…