快速排序算法——C/C++

快速排序算法——C/C++快速排序1、算法思想快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。2、实现原理2.1、设置两个变量low、high,排序开始时:low=0,high=size-1。2.2、整个数组找基准正确位置,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面…

大家好,又见面了,我是你们的朋友全栈君。

快速排序

1. 算法思想

快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。

2. 实现原理

2.1、设置两个变量 low、high,排序开始时:low=0,high=size-1。
2.2、整个数组找基准正确位置,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面

  1. 默认数组的第一个数为基准数据,赋值给key,即key=array[low]。
  2. 因为默认数组的第一个数为基准,所以从后面开始向前搜索(high–),找到第一个小于key的array[high],就将 array[high] 赋给 array[low],即 array[low] = array[high]。(循环条件是 array[high] >= key;结束时 array[high] < key)
  3. 此时从前面开始向后搜索(low++),找到第一个大于key的array[low],就将 array[low] 赋给 array[high],即 array[high] = array[low]。(循环条件是 array[low] <= key;结束时 array[low] > key)
  4. 循环 2-3 步骤,直到 low=high,该位置就是基准位置。
  5. 把基准数据赋给当前位置。

2.3、第一趟找到的基准位置,作为下一趟的分界点。
2.4、递归调用(recursive)分界点前和分界点后的子数组排序,重复2.2、2.3、2.4的步骤。
2.5、最终就会得到排序好的数组。

3. 动态演示

在这里插入图片描述

在这里插入图片描述

4. 完整代码

三个函数
基准插入函数:int getStandard(int array[],int low,int high)
(返回基准位置下标)
递归排序函数:void quickSort(int array[],int low,int high)
主函数:int main()

#include <stdio.h>
#include <stdlib.h>

void display(int* array, int size) { 
   
    for (int i = 0; i < size; i++) { 
   
        printf("%d ", array[i]);
    }
    printf("\n");
}

int getStandard(int array[], int i, int j) { 
   
    // 基准数据
    int key = array[i];
    while (i < j) { 
   
        // 因为默认基准是从左边开始,所以从右边开始比较
        // 当队尾的元素大于等于基准数据 时,就一直向前挪动 j 指针
        while (i < j && array[j] >= key) { 
   
            j--;
        }
        // 当找到比 array[i] 小的时,就把后面的值 array[j] 赋给它
        if (i < j) { 
   
            array[i] = array[j];
        }
        // 当队首元素小于等于基准数据 时,就一直向后挪动 i 指针
        while (i < j && array[i] <= key) { 
   
            i++;
        }
        // 当找到比 array[j] 大的时,就把前面的值 array[i] 赋给它
        if (i < j) { 
   
            array[j] = array[i];
        }
    }
    // 跳出循环时 i 和 j 相等,此时的 i 或 j 就是 key 的正确索引位置
    // 把基准数据赋给正确位置
    array[i] = key;
    return i;
}

void QuickSort(int array[], int low, int high) { 
   
    // 开始默认基准为 low
    if (low < high) { 
   
        // 分段位置下标
        int standard = getStandard(array, low, high);
        // 递归调用排序
        // 左边排序
        QuickSort(array, low, standard - 1);
        // 右边排序
        QuickSort(array, standard + 1, high);
    }
}

// 合并到一起快速排序
// void QuickSort(int array[], int low, int high) { 
   
// if (low < high) { 
   
// int i = low;
// int j = high;
// int key = array[i];
// while (i < j) { 
   
// while (i < j && array[j] >= key) { 
   
// j--;
// }
// if (i < j) { 
   
// array[i] = array[j];
// }
// while (i < j && array[i] <= key) { 
   
// i++;
// }
// if (i < j) { 
   
// array[j] = array[i];
// }
// }
// array[i] = key;
// QuickSort(array, low, i - 1);
// QuickSort(array, i + 1, high);
// }
// }

int main() { 
   
    int array[] = { 
   49, 38, 65, 97, 76, 13, 27, 49, 10};
    int size    = sizeof(array) / sizeof(int);

    // 打印数据
    printf("%d \n", size);
    QuickSort(array, 0, size - 1);
    display(array, size);

    // int size = 20;
    // int array[20] = {0}; // 数组初始化
    // for (int i = 0; i < 10; i++) { // 数组个数
    // for (int j = 0; j < size; j++) { // 数组大小
    // array[j] = rand() % 1000; // 随机生成数大小 0~999
    // }
    // printf("原来的数组:");
    // display(array, size);
    // QuickSort(array, 0, size - 1);
    // printf("排序后数组:");
    // display(array, size);
    // printf("\n");
    // }

    return 0;
}

5. 结果展示

(递归调用,不好展示每次排序结果)
在这里插入图片描述

6. 算法分析

时间复杂度:

  1. 最好: O ( n l o g 2 n ) O(n log_{2} n) O(nlog2n)
  2. 最坏: O ( n 2 ) O(n^2) O(n2)
  3. 平均: O ( n l o g 2 n ) O(n log_{2} n) O(nlog2n)

空间复杂度: O ( n l o g 2 n ) O(n log_{2} n) O(nlog2n)

稳定性:不稳定

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/152562.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月24日 下午3:46
下一篇 2022年6月24日 下午3:46


相关推荐

  • Pycharm 实现远程部署和调试,原来这么简单「建议收藏」

    Pycharm 实现远程部署和调试,原来这么简单「建议收藏」一般代码本地调试完成后,需要运行到服务器上,比如自动化测试脚本、爬虫脚本等,所以第一步需要将项目上传到服务器,然后在服务器上进行调试和运行。但是需要长期维护和开发的项目,这样就繁琐了很多,并且我们时常要维护多个测试或者开发环境,每个环境的Python版本和依赖包有可能还存在差异,这样的话,每次更新需要花费的时间就更多了。其实,很多的编辑器都考虑到这个问题,可以实现远程调试,比如Pycharm、Vscode等。Pycharm可以进行远程部署项目(上传和下载),还可以通过配置远程解释器进行远程调..

    2022年8月28日
    3
  • C++ void指针(void*)简介

    C++ void指针(void*)简介void 是一种特殊的指针类型 可用于存放任意对象的地址 一个 void 指针存放着一个地址 这一点和其他指针类似 在介绍 void 指针前 简单说一下 void 关键字使用规则 如果函数没有返回值 那么应声明为 void 类型 如果函数无参数 那么应声明其参数为 void 常省略 如果函数的参数或返回值可以是任意类型指针 那么应声明其类型为 void void 的字面意思是 无类型 void 则为 无类型指针 void 不能代表一个真实的变量 void 体现了一种抽象 1 任何

    2026年3月19日
    3
  • java笔试题库_java笔试题50道 收藏版

    java笔试题库_java笔试题50道 收藏版1、在JavaEE中,Servlet是在服务器端运行,以处理客户端请求而做出的响应的程序,下列选项中属于Servlet生命周期阶段的是()A、加载和实例化B、初始化C、服务D、销毁E、以上全部答案:E2、在JavaEE中的MVC设计模式中,()负责接受客户端的请求数据A、JavaBeanB、JSPC、ServletD、HTML答案:C3、过滤器应实现的接口是()。A、HttpServle…

    2022年7月7日
    33
  • 【无标题】微信轰炸Java代码

    【无标题】微信轰炸Java代码微信轰炸恶搞小伙伴

    2026年3月19日
    1
  • OpenClaw安装、配置API、常见问题最全详细教程

    OpenClaw安装、配置API、常见问题最全详细教程

    2026年3月13日
    5
  • pip install 使用国内镜像

    pip install 使用国内镜像让PIP源使用国内镜像,提升下载速度和安装成功率。对于Python开发用户来讲,PIP安装软件包是家常便饭。但国外的源下载速度实在太慢,浪费时间。而且经常出现下载后安装出错问题。所以把PIP安装源替换成国内镜像,可以大幅提升下载速度,还可以提高安装成功率。国内源:新版ubuntu要求使用https源,要注意。清华:https://pypi.tuna.tsinghua.edu.cn/…

    2022年6月8日
    35

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号