快速排序

一.什么叫快速排序?

 通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

二.排序步骤:

对下列数组进行排序:(22,36,4,51,36,8,44,5,62,14,5,6,32,12)

1.)找出一个元素作为基准(理论上可以随便找一个)定义两个指针begn和end.
  int x=begn;
  int y=end;
  int s=a[begn];
找第一个元素作为基准
2.)排序实现:
1. 以 22 位基准 ;
2. 在begn位置开始往上找大于等于22的数字;
3.在end处开始往下找小于等于22的数字;
4.找到后交换位置

        while (a[x]<s){
            x++;
        }
        while(a[y]>s){
            y--;
        }
         if(y>=x){
            int tem=a[x];
            a[x]=a[y];
            a[y]=tem;
            x++;
            y--;
        }
第一趟执行结果:
第一趟执行结果
3.)最后重复以上操作调用递归算法:

        if(begn<y){
            Qucli(a,begn,y);
        }
        if(end>x){
            Qucli(a,x,end);
        }

三.完整程序:


public class QuickSort {
  //快速排序
    public static void Qucli(int []a,int begn,int end){
        int x=begn;
        int y=end;
        int s=a[begn];
        while(y>=x){
            while (a[x]<s){
                x++;
            }
            while(a[y]>s){
                y--;
            }
        if(y>=x){
            
            int tem=a[x];
            a[x]=a[y];
            a[y]=tem;
            x++;
            y--;
        }
        
        if(begn<y){
            Qucli(a,begn,y);
        }
        if(end>x){
            Qucli(a,x,end);
        }
    } 
    }
    public static void main(String[] args) {
        int a[]={22,36,4,51,36,8,44,5,62,14,5,6,32,12};
        Qucli(a,0,a.length-1);
        for(int ss:a){
            System.out.print(ss+"  ");
        }
    }

}

结果展示:
快速排序
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 版本记录 前言 将数据结构和算法比作计算机的基石毫不为过,追求程序的高效是每一个软件工程师的梦想。下面就是我对算法...
    刀客传奇阅读 5,230评论 4 72
  • 快速排序(Quicksort)是对冒泡排序的一种改进。 快速排序由C. A. R. Hoare在1962年提出。它...
    Aroli阅读 2,125评论 0 6
  • 1.快速排序 快速排序每趟选择一个基准元素,用基准元素将序列划分成两部分,所有比基准值小的元素摆放在基准前面,所有...
    游戏开发小Y阅读 236评论 0 0
  • 一映入眼帘的“寒门”两个字,脑海中就会想起网络上热议的那篇文章《寒门难再出贵子》这个话题。这篇文章一爆而红,引发了...
    那徐公子阅读 279评论 0 0
  • 我喜欢冬天寒风刺骨的感觉。它让我痛彻心扉!亲临世间的冷漠。重新梳妆自己妩媚的心灵!!
    alll1314阅读 234评论 0 1