欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

经典算法学习——快速排序_PHP教程

程序员文章站 2022-05-14 14:03:50
...

经典算法学习——快速排序

快速排序应该算是在面试笔试中最常用的算法了,各位面试官都非常喜欢。排序效率在同为O(N*logN)的几种排序方法中效率较高,因此经常被采用,其中的思想也是用了分治法和递归的思想。示例代码上传到:https://github.com/chenyufeng1991/QuickSort

算法的基本思想是:

(1)先从数列中取出一个数作为基准数(常常选第一个数);

(2)分区过程,比这个数大的数放到它的右边,小于或等于的数全放到它的左边;

(3)再对左右区间重复第二步,直到每个区间只有一个数位置,即左边界下标等于右边界下标;

简化描述为:

1.i= L, j=R,基准数即为a[i],保存起来;

2.j--,由后向前找比它小的数,找到后将此数放到a[i]中;

3.i++,由前向后找比它大的数,找到后将此数填入到a[j]中;

4.递归执行2,3两步,直到i==j,最后将基准数填入a[i]中;

具体代码实现如下:

//
//  main.c
//  QuickSort
//
//  Created by chenyufeng on 16/1/27.
//  Copyright © 2016年 chenyufengweb. All rights reserved.
//

#include 

int *quickSort(int arr[],int l,int r);
void quickSort02(int *arr,int l,int r);

int main(int argc, const char * argv[]) {

    int numArr[5] = {3,6,0,9,4};

    //使用指针返回数组,返回的其实是数组的头指针;
    /**
     *  使用返回指针;
     */

//    int *retArr;
//    retArr = quickSort(numArr, 0, 4);
//    for (int i = 0; i = x) {
                j--;
            }
            if (i = x) {
                j--;
            }
            if (i 

www.bkjia.comtruehttp://www.bkjia.com/PHPjc/1119561.htmlTechArticle经典算法学习——快速排序 快速排序应该算是在面试笔试中最常用的算法了,各位面试官都非常喜欢。排序效率在同为O(N*logN)的几种排序方...
相关标签: 算法 经典