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;
}

**

测试:

相关推荐
weixin_4576653911 分钟前
C++11新标准
开发语言·c++
蒙奇D索大34 分钟前
【数据结构】图论最短路径算法深度解析:从BFS基础到全算法综述
数据结构·算法·图论·广度优先·图搜索算法
trouvaille35 分钟前
哈希数据结构的增强
算法·go
我不是小upper1 小时前
L1和L2核心区别 !!--part 2
人工智能·深度学习·算法·机器学习
奔跑吧邓邓子1 小时前
解锁Vscode:C/C++环境配置超详细指南
c语言·c++·vscode·配置指南
虾球xz1 小时前
CppCon 2015 学习:Reactive Stream Processing in Industrial IoT using DDS and Rx
开发语言·c++·物联网·学习
liujing102329292 小时前
Day09_刷题niuke20250609
java·c++·算法
不7夜宵2 小时前
力扣热题100 k个一组反转链表题解
算法·leetcode·链表
Bardb2 小时前
02__C++的基本语法
c++·qt
freyazzr3 小时前
C++八股 | Day3 | 智能指针 / 内存管理 / 内存分区 / 内存对齐
开发语言·c++