每日OJ题_分治快排①_力扣75. 颜色分类(快排原理)

目录

分治快排算法原理

[力扣75. 颜色分类](#力扣75. 颜色分类)

解析代码


分治快排算法原理

分治就是分而治之,快排在数据结构也学过了,现在来学一学三路划分快排(数组划分三块):

前面我们已经实现了三个版本的快速排序的算法,分别是hoare法,挖坑法和前后指针法。但是前面的三个版本的快速排序在某些极端场景中效率都会变得很低,例如大部分都是同一个数的时候,前面的三种方法都不能很高效地完成排序,时间复杂度退化成了O(N^2),所以有必要对之前的排序方法进行一些改进,使它能够适应包含任何数据的数组。于是就有大佬想出了一个更牛的方法,那就是三路划分快排。

三路划分快排的思路: 三路划分,顾名思义就是把数组分成三个部分进行排序,在待排序数组中随机选定一个key,把数组分成小于key的,等于key的,还有大于key的。

具体操作是:

  • 定义一个left下标为数组首元素下标的前一个位置,即left=begin-1;
  • 再定义一个right下标为数组最后一个元素的下标的后一个位置,即right=end+1;
  • 再定义一个下标cur=left,作为遍历数组的下标,一共就left,cur,right三个下标。
  • 从acur开始与key比较,如果acur<key,就用acur和a++left交换(记住这里是先++,后交换),然后++cur;如果acur>key,就用acur和a- -right交换(记住这里是先减减,后交换);如果acur==key,那就只++cur即可,
  • 这样循环往复,直到cur=right就结束,最后得到的abegin,left是比key小的数,aleft+1,right-1是等于key的数,aright,end是大于key的数,划分成三路之后,中间这一路就不用再进行排序了,因为中间这一路都是等于key的,所以已经有序了,只需要对左路和右路再进行递归排序即可。

下面先做一道三路划分思想的题,然后再是快排排序数组。


力扣75. 颜色分类

75. 颜色分类

难度 中等

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

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

必须在不使用库内置的 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]012

进阶:

  • 你能想出一个仅使用常数空间的一趟扫描算法吗?
cpp 复制代码
class Solution {
public:
    void sortColors(vector<int>& nums) {

    }
};

解析代码

数组分三块:三指针思想:left i right,

0 到 left 全是 0,right 到 i 全是 1,i 到 right 全是未处理的元素,right到nums.size();全是2。

cpp 复制代码
class Solution {
public:
    void sortColors(vector<int>& nums) {
        int left = -1, i = 0, right = nums.size();
        while(i < right)
        {
            if(nums[i] == 0)
            {
                swap(nums[++left], nums[i++]);
            }
            else if(nums[i] == 1)
            {
                ++i;
            }
            else // == 2
            {
                swap(nums[--right], nums[i]);
            }
        }
    }
};
相关推荐
星恒随风3 分钟前
C++ string 入门(一)
开发语言·c++·笔记·学习
旖-旎3 分钟前
《LeetCode 200 FloodFill 岛屿数量DFS解法》
c++·算法·深度优先·力扣·floodfill
拂拉氏6 分钟前
【知识讲解-题目讲解】算法系列之动态规划入门(下)
算法·leetcode·动态规划
skywalk81639 分钟前
继续推进心语项目6.15 @CodeArts
开发语言·算法·编程
2601_961845159 分钟前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
前进吧-程序员10 分钟前
反转链表完全指南:辅助容器、三指针、头插法
数据结构·c++·链表
我不是懒洋洋13 分钟前
从零实现一个分布式配置中心:服务发现与热更新
c++
开开心心就好13 分钟前
自动生成小学数学题库支持导出Word
人工智能·安全·leetcode·贪心算法·ocr·音视频·语音识别
bIo7lyA8v14 分钟前
算法复杂度的可视化评估与优化策略研究的技术8
算法
省四收割者15 分钟前
从硬件中断到分布式协程:全景解构高并发机制与 C / Golang 的巅峰对决
c++·分布式·嵌入式硬件·golang