LeetCode热题100(颜色分类)

题目描述

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

我们使用整数 012 分别表示红色、白色和蓝色。

必须在不使用库内置的 sort 函数的情况下解决这个问题。

题解:

java 复制代码
class Solution {
    public void sortColors(int[] nums) {
        int n = nums.length;
        int ptr = 0;
        for(int i = 0; i < n; ++i){
            if(nums[i] == 0){
                int temp = nums[i];
                nums[i] = nums[ptr];
                nums[ptr] = temp;
                ++ptr;
            }
        }
        for(int i = ptr;i < n;++i){
            if(nums[i] == 1){
                int temp = nums[i];
                nums[i] = nums[ptr];
                nums[ptr] = temp;
                ++ptr;
            }
        }
    }
}

题解思路:

1.数组中只存在0,1,2三种数字,遍历数组,找到数字为0的数据并排序到最前面。需使用1个变量记录,并通过temp变量进行交换。

2.寻找数字为1的数值并通过交换放在0的后面,这个时候需基于之前的ptr值开始遍历。

相关推荐
说文科技2 小时前
大模型项目实战之dpo微调
人工智能·算法
睡一觉就好了。2 小时前
归并排序——递归与非递归的双重实现
数据结构·算法·排序算法
酉鬼女又兒2 小时前
SQL23 统计每个学校各难度的用户平均刷题数
数据库·sql·算法
爱学习的阿磊2 小时前
模板代码跨编译器兼容
开发语言·c++·算法
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于协同过滤推荐算法的小说漫画网站设计与实现为例,包含答辩的问题和答案
算法·机器学习·推荐算法
u0109272712 小时前
代码覆盖率工具实战
开发语言·c++·算法
We་ct2 小时前
LeetCode 73. 矩阵置零:原地算法实现与优化解析
前端·算法·leetcode·矩阵·typescript
天赐学c语言2 小时前
2.1 - 反转字符串中的单词 && 每个进程的内存里包含什么
c++·算法·leecode
程序员泠零澪回家种桔子2 小时前
OpenManus开源自主规划智能体解析
人工智能·后端·算法