快速排序

本文深入讲解了快速排序算法的核心思想及其实现过程,包括如何选取pivot,以及通过递归进行左右子数组的排序。提供了C++和C语言的代码实现,并详细解释了get_index函数的作用和工作原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

快速排序

测试代码,使用一个通用测试c++代码,代码如下

#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
int main(){
    int val[10];
    srand((unsigned int)time(0));//随机数种子
    for(int i=0;i<10;i++) val[i]=(int)rand();//生成随机数
    for(int i=0;i<10;i++) cout<<val[i]<<" ";//输出初始数字
    cout<<endl;
    //这边调用排序方法
    for(int i=0;i<10;i++) cout<<val[i]<<" ";//输出排序后的数字
    cout<<endl;
    system("pause");
    return 0;
}

1.经典快速排序

伪代码

quick_sort(int* arr,int left,int right){
    if left>right 递归终止
    pivot = get_index(arr,left,right)
    quick_sort(arr,0,pivot-1)
    quick_sort(arr,pivot+1)
}
get_index(int* arr,int left,int right){
    tmp=arr[left]
    while left<right
        while left<right and arr[right]>=tmp
            right--
        arr[left]=arr[right]
        while left<right and arr[left]<=tmp
            left++
        arr[right]=arr[left]
    arr[left]=tmp
    return left
}

主要思想

1.找到pivot,进行左右递归,递归终止条件,左边数小于右边数

2.找到pivot方法,进行记住左边的数

​ 当右边数大于记住的数,右边指针左移

​ 右值赋值到左边

​ 当左边数小于记住的数,左边指针右移

​ 将左值移动到右边

​ 左值填充记住的数字

C语言代码实现

int get_index(int* arr,int left,int right){
    int tmp=arr[left];
    while(left<right){
        while(left<right&&arr[right]>=tmp) right--;
        arr[left]=arr[right];
        while(left<right&&arr[left]<=tmp) left++;
        arr[right]=arr[left];
    }
    arr[left]=tmp;
    return left;
}
void quick_sort(int* arr,int left,int right){
    if(left>right) return;
    int pivot=get_index(arr,left,right);
    //left是中介点
    quick_sort(arr,0,pivot-1);
    quick_sort(arr,pivot+1,right);
}

转载于:https://www.cnblogs.com/littlepage/p/11592944.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值