力扣第 75 题是 颜色分类

题目描述

输入 :一个数组 nums,其中元素只能是 012

输出:对数组进行排序,使其按顺序排列。

你需要使用 原地算法,即不能使用额外的空间来完成排序。


示例

示例 1

输入

plaintext 复制代码
nums = [2, 0, 2, 1, 1, 0]

输出

plaintext 复制代码
[0, 0, 1, 1, 2, 2]
示例 2

输入

plaintext 复制代码
nums = [2, 0, 1]

输出

plaintext 复制代码
[0, 1, 2]

解题思路

1. 计数排序
  • 遍历数组,统计 012 的个数。
  • 然后按照统计的数量依次将 012 填回数组。

这种方法需要两次遍历,时间复杂度为 O(n) ,空间复杂度为 O(1)


2. 双指针法

使用三个指针:

  • p0:指向下一个应该放置 0 的位置。
  • p2:指向下一个应该放置 2 的位置。
  • curr:用于遍历数组。

算法过程

  1. 初始化 p0 = 0curr = 0p2 = n - 1
  2. 遍历数组:
    • 如果 nums[curr] == 0:将 nums[curr]nums[p0] 交换,p0++curr++
    • 如果 nums[curr] == 2:将 nums[curr]nums[p2] 交换,p2--,但此时 curr 不前进(因为交换过来的元素还需要检查)。
    • 如果 nums[curr] == 1curr++

这种方法只需一次遍历,时间复杂度为 O(n) ,空间复杂度为 O(1)


实现代码

双指针法实现
c 复制代码
#include <stdio.h>

void sortColors(int* nums, int numsSize) {
    int p0 = 0, curr = 0, p2 = numsSize - 1;

    while (curr <= p2) {
        if (nums[curr] == 0) {
            // 交换 nums[curr] 和 nums[p0]
            int temp = nums[curr];
            nums[curr] = nums[p0];
            nums[p0] = temp;
            p0++;
            curr++;
        } else if (nums[curr] == 2) {
            // 交换 nums[curr] 和 nums[p2]
            int temp = nums[curr];
            nums[curr] = nums[p2];
            nums[p2] = temp;
            p2--;
        } else {
            curr++;
        }
    }
}

int main() {
    int nums[] = {2, 0, 2, 1, 1, 0};
    int numsSize = sizeof(nums) / sizeof(nums[0]);

    sortColors(nums, numsSize);

    // 输出排序后的数组
    for (int i = 0; i < numsSize; i++) {
        printf("%d ", nums[i]);
    }
    printf("\n");

    return 0;
}

代码解析

  1. 变量初始化

    • p0 指向当前应该放 0 的位置。
    • p2 指向当前应该放 2 的位置。
    • curr 遍历数组。
  2. 循环逻辑

    • 如果 nums[curr] == 0
      • 交换 nums[curr]nums[p0]
      • 更新 p0curr
    • 如果 nums[curr] == 2
      • 交换 nums[curr]nums[p2]
      • 更新 p2
    • 如果 nums[curr] == 1
      • 直接更新 curr
  3. 结束条件

    • curr > p2 时,所有元素已经按要求排序。

时间复杂度和空间复杂度

  • 时间复杂度

    • 只需一次遍历,时间复杂度为 O(n)
  • 空间复杂度

    • 没有使用额外的空间,空间复杂度为 O(1)
相关推荐
zy_destiny15 小时前
【工业场景】用YOLOv26实现8种道路隐患检测
人工智能·深度学习·算法·yolo·机器学习·计算机视觉·目标跟踪
寄存器漫游者15 小时前
数据结构 二叉树与哈希表
数据结构·散列表
怡步晓心l15 小时前
Mandelbrot集合的多线程并行计算加速
c++·算法·缓存
老鼠只爱大米15 小时前
LeetCode经典算法面试题 #114:二叉树展开为链表(递归、迭代、Morris等多种实现方案详细解析)
算法·leetcode·二叉树·原地算法·morris遍历·二叉树展开
Ivanqhz15 小时前
现代异构高性能计算(HPC)集群节点架构
开发语言·人工智能·后端·算法·架构·云计算·边缘计算
参.商.16 小时前
【Day25】26.删除有序数组中的重复项 80.删除有序数组中的重复项II
leetcode·golang
Sayuanni%316 小时前
数据结构_Map和Set
java·数据结构
HyperAI超神经16 小时前
覆盖天体物理/地球科学/流变学/声学等19种场景,Polymathic AI构建1.3B模型实现精确连续介质仿真
人工智能·深度学习·学习·算法·机器学习·ai编程·vllm
执着25916 小时前
力扣hot100 - 144、二叉树的前序遍历
数据结构·算法·leetcode
范纹杉想快点毕业16 小时前
嵌入式系统架构之道:告别“意大利面条”,拥抱状态机与事件驱动
java·开发语言·c++·嵌入式硬件·算法·架构·mfc