排序算法----快速排序----详解&&代码

简介: 排序算法----快速排序----详解&&代码

快速排序:


基本思想:在数列进行快速排序时,选择第一个数为基准值(begin),判断if(left>begin)就swap(left,right),然后right–(向前移一位),if(left<begin)就left++(left向前移一位),当left和right移到一起


就把基准值插入到数列中,循环结束后,left=right,原本数列a[begin+1]~a[end],左边比基准值小,右边比基准值大,

然后把基准值插入到合适序列中,判断基准值比最后left和right共同指的那个数哪个大

如果基准值比它大就放在它后边(交换就行)如果基准值比它小就放在它前边(基准值直接和left-1交换)

代码:

//快速排序
void QuickSort(int data[], int begin, int end)
{
    int temp;
    int left = begin + 1;
    int right = end;
    if (begin < end) //数列中存在数据进入排序
    {
        while (left < right)
        {
            //判断基准值与left的大小
            if (data[begin] < data[left])
            {
                //交换a[left]和a[right]的值,right--
                swap(&data[left], &data[right]);
                right--;
            }
            else
                left++;
        }
        //循环结束后,left=right,原本数列a[begin+1]~a[end],左边比基准值小,右边比基准值打,然后把基准值插入到合适序列中
        //判断基准值比最后left和right共同指的那个数哪个大
        //如果基准值比它大就放在它后边(交换就行)
        //如果基准值比它小就放在它前边(基准值直接和left-1交换)
        if (data[begin] > data[left])
        {
            swap(&data[begin], &data[left]);
        }
        else
        {
            left--;
            swap(&data[begin], &data[left]);
        }
        //此时原本数列a[begin]~a[end]就被分成了两个数列     a[begin]~a[left-1]和a[left+1]~a[end]
        QuickSort(data, begin, left);
        QuickSort(data, left + 1, end);
    }
}
相关文章
|
17天前
|
存储 算法 调度
【复现】【遗传算法】考虑储能和可再生能源消纳责任制的售电公司购售电策略(Python代码实现)
【复现】【遗传算法】考虑储能和可再生能源消纳责任制的售电公司购售电策略(Python代码实现)
122 26
|
17天前
|
存储 编解码 算法
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
【多光谱滤波器阵列设计的最优球体填充】使用MSFA设计方法进行各种重建算法时,图像质量可以提高至多2 dB,并在光谱相似性方面实现了显著提升(Matlab代码实现)
|
19天前
|
传感器 机器学习/深度学习 算法
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
【使用 DSP 滤波器加速速度和位移】使用信号处理算法过滤加速度数据并将其转换为速度和位移研究(Matlab代码实现)
105 1
|
18天前
|
传感器 机器学习/深度学习 算法
【UASNs、AUV】无人机自主水下传感网络中遗传算法的路径规划问题研究(Matlab代码实现)
【UASNs、AUV】无人机自主水下传感网络中遗传算法的路径规划问题研究(Matlab代码实现)
|
14天前
|
机器学习/深度学习 人工智能 搜索推荐
从零构建短视频推荐系统:双塔算法架构解析与代码实现
短视频推荐看似“读心”,实则依赖双塔推荐系统:用户塔与物品塔分别将行为与内容编码为向量,通过相似度匹配实现精准推送。本文解析其架构原理、技术实现与工程挑战,揭秘抖音等平台如何用AI抓住你的注意力。
226 7
从零构建短视频推荐系统:双塔算法架构解析与代码实现
|
17天前
|
机器学习/深度学习 传感器 算法
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
【高创新】基于优化的自适应差分导纳算法的改进最大功率点跟踪研究(Matlab代码实现)
119 14
|
12天前
|
机器学习/深度学习 传感器 算法
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
【无人车路径跟踪】基于神经网络的数据驱动迭代学习控制(ILC)算法,用于具有未知模型和重复任务的非线性单输入单输出(SISO)离散时间系统的无人车的路径跟踪(Matlab代码实现)
|
12天前
|
canal 算法 vr&ar
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
【图像处理】基于电磁学优化算法的多阈值分割算法研究(Matlab代码实现)
|
17天前
|
机器学习/深度学习 运维 算法
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
|
19天前
|
存储 机器学习/深度学习 算法
基于A星算法的无人机三维路径规划算法研究(Mattlab代码实现)
基于A星算法的无人机三维路径规划算法研究(Mattlab代码实现)

热门文章

最新文章