【LeetCode:75. 颜色分类 + 快速排序】

|-----------|
| 🚀 算法题 🚀 |

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域新星创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

|-----------|
| 🚀 算法题 🚀 |

🍔 目录

    • [🚩 题目链接](#🚩 题目链接)
    • [⛲ 题目描述](#⛲ 题目描述)
    • [🌟 求解思路&实现代码&运行结果](#🌟 求解思路&实现代码&运行结果)
      • [⚡ 快速排序](#⚡ 快速排序)
        • [🥦 求解思路](#🥦 求解思路)
        • [🥦 实现代码](#🥦 实现代码)
        • [🥦 运行结果](#🥦 运行结果)
    • [💬 共勉](#💬 共勉)

🚩 题目链接

⛲ 题目描述

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

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

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

示例 1:

输入:nums = [2,0,2,1,1,0]

输出:[0,0,1,1,2,2]

示例 2:

输入:nums = [2,0,1]

输出:[0,1,2]

提示:

n == nums.length

1 <= n <= 300

nums[i] 为 0、1 或 2

进阶:

你能想出一个仅使用常数空间的一趟扫描算法吗?

🌟 求解思路&实现代码&运行结果


⚡ 快速排序

🥦 求解思路
  1. 该题目的要求是通过一次遍历,把数组分成三个部分,是快速排序的partition过程。
  2. 我们可以通过俩个指针zero,two来分别记录0位置和2位置的下标,i位置表示此时走到的位置;
    • 如果此时数值是0,交换swap(zero,i)数组中元素,i++,zero++;
    • 如果此时数值是1,i++;
    • 如果此时数值是2,two--,然后交换swap(i,two)的元素。
  3. 循环结束,得到有序数组。
  4. 实现代码如下。
🥦 实现代码
java 复制代码
class Solution {
    public void sortColors(int[] nums) {
        int n = nums.length;
        int zeroIndex = 0, twoIndex = n;
        int i = 0;
        while (i < twoIndex) {
            if (nums[i] == 0) {
                swap(nums, i, zeroIndex);
                zeroIndex++;
                i++;
            } else if (nums[i] == 1) {
                i++;
            } else {
                twoIndex--;
                swap(nums, i, twoIndex);
            }
        }
    }

    public void swap(int[] nums, int i, int j) {
        int temp = nums[i];
        nums[i] = nums[j];
        nums[j] = temp;
    }
}
🥦 运行结果

💬 共勉

|----------------------------------|
| 最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉! |

相关推荐
勇敢滴勇7 分钟前
【排序算法】选择排序、堆排序
数据结构·算法·排序算法
MrBlackmzq12 分钟前
Datawhale Leecode基础算法篇 task04:贪心算法
python·算法·贪心算法
Pandaconda38 分钟前
【计算机网络 - 基础问题】每日 3 题(二十七)
开发语言·经验分享·笔记·后端·计算机网络·面试·职场和发展
Satan71242 分钟前
【Java】虚拟机(JVM)内存模型全解析
java·开发语言·jvm
洛小豆1 小时前
前端开发必备:三种高效定位动态类名元素的 JavaScript 技巧
开发语言·前端·javascript·面试
Pandaconda1 小时前
【计算机网络 - 基础问题】每日 3 题(二十四)
开发语言·经验分享·笔记·后端·计算机网络·面试·职场和发展
啵一杯1 小时前
leetcode621. 任务调度器
服务器·前端·数据结构·算法·c#
远望樱花兔2 小时前
【d54_2】【Java】【力扣】142.环形链表
java·leetcode·链表
IT学长编程2 小时前
计算机毕业设计 助农产品采购平台的设计与实现 Java实战项目 附源码+文档+视频讲解
java·spring boot·毕业设计·课程设计·毕业论文·计算机毕业设计选题·助农产品采购平台
2401_857297912 小时前
2025校招内推-招联金融
java·前端·算法·金融·求职招聘