快速排序(C++实现)

基本思想

任取一个元素为中心,所有比它小的元素一律前放,比他大的元素一律后放,形成左右两个子表;对各子表重新选择中心元素并依此规则调整,直到每个子表的元素只剩一个。

通过一趟排序,将待排序记录分割成独立的两部分,其中一部分记录的关键字都比两一部分记录的关键字小,则可对这两部分记录进行排序,以达到整个序列有序。

调试代码

cpp 复制代码
#include <iostream>
#include <vector>
using namespace std;
int counter = 0;//调试用

int Partition(vector<int>&vec, int low, int high)
{
    //首先以第一个元素的值作为枢轴的值,此时它所在的位置空出来,然后从后往前遍历,将第一个小于枢轴的值的元素放到空位
    int pivotVal = vec[low];   // 选取第一个元素的值作为枢轴的值
    while (low < high)
    {
        while (low < high && vec[high] >= pivotVal) high--;   // 从后往前遍历,直到遇到比枢轴小的元素时停下
        swap(vec[low], vec[high]);
        while (low < high && vec[low] <= pivotVal) low++;    // 从前往后遍历,直到遇到比枢轴大的元素时停下
        swap(vec[low], vec[high]);
    }
    vec[low] = pivotVal;

    cout << "第" << ++counter << "趟: ";
    for (int i = 0; i < 11; i++)
        cout << vec[i] << "   ";
    cout << endl << endl;
    return low;
}
void quick_sort(vector<int>& vec, int low, int high)
{
    if (low < high)
    {
        int pivot = Partition(vec, low, high);  // 确定枢轴的位置
        quick_sort(vec, low, pivot - 1);        // 对 左边子序列 递归排序
        quick_sort(vec, pivot + 1, high);       // 对 右边子序列 递归排序
    }
}
int main(int argc, const char* argv[])
{
    vector<int> vec = { 100, 1, 53, 5, 36, 7, 8, 109,  10, 11, 15 };
    cout << "待排序数组: ";
    for (int i = 0; i < 11; i++)
        cout << vec[i] << " ";
    cout << endl << endl;
    quick_sort(vec, 0, vec.size() - 1);

    cout << "结果: ";
    for (int i = 0; i < 11; i++)
        cout << vec[i] << " ";
    cout << endl << endl;
    return 0;
}
相关推荐
胡萝卜3.02 小时前
掌握string类:从基础到实战
c++·学习·string·string的使用
爱coding的橙子2 小时前
每日算法刷题Day70:10.13:leetcode 二叉树10道题,用时2h
算法·leetcode·深度优先
江公望2 小时前
通过QQmlExtensionPlugin进行Qt QML插件开发
c++·qt·qml
Syntech_Wuz2 小时前
从 C 到 C++:容器适配器 std::stack 与 std::queue 详解
数据结构·c++·容器··队列
ghie90903 小时前
基于MATLAB的遗传算法优化支持向量机实现
算法·支持向量机·matlab
朝新_3 小时前
【优选算法】第一弹——双指针(上)
算法
艾莉丝努力练剑4 小时前
【C++STL :stack && queue (一) 】STL:stack与queue全解析|深入使用(附高频算法题详解)
linux·开发语言·数据结构·c++·算法
胡萝卜3.04 小时前
深入理解string底层:手写高效字符串类
开发语言·c++·学习·学习笔记·string类·string模拟实现
kyle~4 小时前
计算机系统---CPU的进程与线程处理
linux·服务器·c语言·c++·操作系统·计算机系统
CoovallyAIHub4 小时前
ICLR 2026 惊现 SAM 3,匿名提交,实现“概念分割”,CV领域再迎颠覆性突破?
深度学习·算法·计算机视觉