C++ 快排算法

今天看到一种清爽的快速算法,复习一下~

快速排序算法的平均时间复杂度是O(n log n),最坏情况下的时间复杂度是O(n^2)。
快速排序的最佳情况是每次分割都平均分配元素,这种情况下时间复杂度可降至O(n log n)。

快速排序的基本步骤如下:

1、选择一个"基准"元素。可以选择第一个元素、最后一个元素、中间元素,或者随机选择一个元素作为基准。
2、重新排列数组。把所有比基准小的元素放在基准前面,所有比基准大的元素放在基准的后面。
3、递归把小于基准元素的子数组和大于基准元素的子数组进行快速排序。

贴代码:

cpp 复制代码
**// Test.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
//

#include <iostream>
#include <vector>
using namespace std;

vector<int> QuickSort(vector<int>& arr)
{
    // 如果数组长度小于等于1,直接返回
    if (arr.size() <= 1) 
    {
        return arr; 
    }

    int mid = arr[arr.size() / 2]; // 选择中间元素作为基准
    vector<int> left; // 存小于基准的元素
    vector<int> middle; // 存等于基准的元素
    vector<int> right; // 存大于基准的元素

    for (const auto& it: arr) 
    {
        if (it == mid)
        {
            middle.push_back(it); // 等于基准的元素放入 middle
        }
		else if (it < mid)
        {
            left.push_back(it); // 小于基准的元素放入 left
        }
        else if (it > mid)
        {
            right.push_back(it); // 大于基准的元素放入 right
        }
    }

    // 递归排序 left 和 right,并将结果合并
    vector<int> sortedLeft = QuickSort(left);
    vector<int> sortedRight = QuickSort(right);

    // 合并结果
    vector<int> result;
    result.insert(result.end(), sortedLeft.begin(), sortedLeft.end());
    result.insert(result.end(), middle.begin(), middle.end());
    result.insert(result.end(), sortedRight.begin(), sortedRight.end());

    return result;
}


int main()
{
	vector<int> arr = { 2,5,8,9,0,7,6,1,3,4 };
	auto result = QuickSort(arr);
	
    for (const auto& it : result)
    {
        cout << it << "\t";
    }

	cin.get();
	return 0;
}

**

测试:

相关推荐
Fcy64815 小时前
算法基础详解(二)枚举算法——普通枚举与二进制枚举
算法·枚举算法
承渊政道16 小时前
【优选算法】(实战:栈、队列、优先级队列高频考题通关全解)
数据结构·c++·笔记·学习·算法·leetcode·宽度优先
py有趣16 小时前
力扣热门100题之将有序数组转为二叉搜索树
算法·leetcode
天若有情67316 小时前
Python精神折磨系列(完整11集·无断层版)
数据库·python·算法
凌波粒16 小时前
LeetCode--383.赎金信(哈希表)
java·算法·leetcode·散列表
liulilittle16 小时前
OPENPPP2 1.0.0.26145 正式版发布:内核态 SYSNAT 性能飞跃 + Windows 平台避坑指南
开发语言·网络·c++·windows·通信·vrrp
AIminminHu16 小时前
OpenGL渲染与几何内核那点事-项目实践理论补充(三-1-(2):当你的CAD代码变得“又大又乱”:从手动编译到CMake,从随性编码到单元测试))
c++·单元测试·cmake·cad·cad开发
xiaoye-duck16 小时前
《算法题讲解指南:动态规划算法--子数组系列》--23.等差数列划分,24.最长湍流子数组
c++·算法·动态规划
消失的旧时光-194316 小时前
C++ 网络服务端主线:从线程池到 Reactor 的完整路线图
开发语言·网络·c++·线程池·并发
小O的算法实验室16 小时前
2026年SEVC,高密度仓库中结合任务分配的多AGV无冲突调度框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进