LeetCode第75题颜色分类

继续打卡算法题,今天学习的是LeetCode第75题颜色分类,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

看完题目就知道,其实本题是排序题,本题就是要对数组从小到大排序。

常见的排序算法有冒泡排序,快速排序,归并排序。 而本题数组元素是特殊的,只有可能是0,1,2, 所以可以不按排序法解决,很多重复元素。

我们可以循环一遍数组将0移动到数组头部,同时记录0的最终位置。

再循环一遍将1移动到数组中间,这样数组就排序了。

时间复杂度O(n^2)。

哈哈,还有一种更加巧妙的办法,那就是双指针法,我们可以使用两个指针p0,p1分别用来交换0和2的

一开始,p0指向数组下标0 ,p1指向数组下标n-1

然后遍历数组,遇到了0,将0移动到p0位置,将p0指针往后移动,遇到了2,将p1指向往前移动

本题解题技巧

1、根据数组中只有0,1,2的情况,使用两个指针处理0和1的元素,巧妙的解决此题

编码解决

java 复制代码
class Solution {
    public void sortColors(int[] nums) {
        int n = nums.length;
        int p0 = 0, p2 = n - 1;
        for (int i = 0; i <= p2; ++i) {
            
            while (i <= p2 && nums[i] == 2) {
                int temp = nums[i];
                nums[i] = nums[p2];
                nums[p2] = temp;
                --p2;
            }
            if (nums[i] == 0) {
                int temp = nums[i];
                nums[i] = nums[p0];
                nums[p0] = temp;
                ++p0;
            }
        }
    }
}

总结

1、双指针法遍历数组很有用,

相关推荐
dreams_dream13 小时前
Django序列化器
后端·python·django
懷淰メ13 小时前
python3GUI--短视频社交软件 By:Django+PyQt5(前后端分离项目)
后端·python·django·音视频·pyqt·抖音·前后端
有意义14 小时前
从零搭建:json-server+Bootstrap+OpenAI 全栈 AI 小项目
前端·后端·llm
mm-q291522272914 小时前
【天野学院5期】 第5期易语言半内存辅助培训班,主讲游戏——手游:仙剑奇侠传4,端游:神魔大陆2
人工智能·算法·游戏
MoRanzhi120314 小时前
Python 实现:从数学模型到完整控制台版《2048》游戏
数据结构·python·算法·游戏·数学建模·矩阵·2048
2401_8414956415 小时前
【数据结构】基于BF算法的树种病毒检测
java·数据结构·c++·python·算法·字符串·模式匹配
汤姆yu15 小时前
基于springboot的民间救援队救助系统
java·spring boot·后端·救援队
嵌入式学习之旅15 小时前
嵌入式面试1103
面试·职场和发展
蒙奇D索大15 小时前
【算法】递归算法实战:汉诺塔问题详解与代码实现
c语言·考研·算法·面试·改行学it
IT_陈寒15 小时前
React性能优化实战:这5个Hooks技巧让我的应用快了40%
前端·人工智能·后端