`

关于快速排序算法一篇比较不错的说明

 
阅读更多
另一种经典的交换排序是快速排序,快速排序的效率很高,但是空间复杂度较大,因为快速排序使用了递归,而递归的实现需要一个栈。快速排序的算法思想是:(假设数据存放在数组a[n]中)
  1.如果待比较的数组长度为0或者1,则不用比较,直接返回。
  2.如果待比较的数组长度大于1,则随机的选择一个中枢值(centrum),然后分别从数组的两端开始遍历,并且把从左边遍历找到的大于centrum的元素和从右边遍历找到的小于centrum的元素进行交换,直到数组遍历完毕(即:左边遍历指针指向的索引大于或等于右边遍历指针指向的索引)。
  3.交换中枢元素和右边遍历指针指向的元素,这样原来的数组以中枢元素为界分成了两个数组,且左边数组的元素都不大于中枢,右边数组的元素都不小于中枢,然后分别对两个子数组分别进行快速排序。
  快速排序的java实现如下:

public static void quickSort(int[] elements,int begin,int end){
if(begin < end){
int centrum = elements[begin];//选择第一个元素作为中枢
int front = begin+1;
int back = end;
while(front <= back){ //第一次排序从左边右边同时开始搜索到中
//间停止
while((front <= end) && (elements[front] < centrum)) front++;
//从左向右搜找出比centrum大的 elements[front] >= centrum
while((back >= begin) && (elements[back] > centrum)) back--;
//从右向左搜 找出比centrum小的 elements[back] <= centrum
if(front < back){
swap(elements,front,back);//如果搜出来的两个结果
//的序列号front<back 则交换两个结果的位置。否则跳出循环,即搜索的指针相遇了

}else{
break;
}
}
//分割成两个块比centrum小的,比centrum大的
if(begin < back)
swap(elements,begin,back);//交换centrum和最后从右边搜索
//出来的比centrum小的一个元素,交换他们的位置,这样back索引左边
//的都比它小。

quickSort(elements,begin,back-1);
quickSort(elements,back+1,end);
}
}

private static void swap(int[] elements,int i, int j){
int temp = elements[i];
elements[i] = elements[j];
elements[j] = temp;
}

public static void main(String[] args) {
int [] a = new int[]{5,3,7,9,1,2,6,4,8};
quickSort(a, 0, a.length - 1);
for (int i = 0; i < a.length; i++) {
System.out.println(a[i]);
}

}
分享到:
评论

相关推荐

    排序算法 各种算法的综合

    排序算法是一种基本并且常用的算法。由于实际工作中处理的数量巨大,所以排序算法 对算法本身的速度要求很高。 而一般我们所谓的算法的性能主要是指算法的复杂度,一般用O方法来表示。在后面我将 给出详细的说明...

    谭浩强C语言程序设计,C++程序设计,严蔚敏数据结构,高一凡数据结构算法分析与实现.rar )

    2.4 怎样表示一个算法 24 2.4.1 用自然语言表示算法 24 2.4.2 用流程图表示算法 24 2.4.3 三种基本结构和改进的流程图 28 2.4.4 用N-S 流程图表示算法 29 2.4.5 用伪代码表示算法 30 2.4.6 用计算机语言表示算法 31 ...

    谭浩强C语言程序设计,C++程序设计,严蔚敏数据结构,高一凡数据结构算法分析与实现.rar

    2.4 怎样表示一个算法 24 2.4.1 用自然语言表示算法 24 2.4.2 用流程图表示算法 24 2.4.3 三种基本结构和改进的流程图 28 2.4.4 用N-S 流程图表示算法 29 2.4.5 用伪代码表示算法 30 2.4.6 用计算机语言表示算法 31 ...

    C++入门到精通

    第 1 章和第2 章形成了一个独立完整的C++介绍和概述 第一篇的目的是使我们快速地 理解C++支持的概念和语言设施 以及编写和执行一个程序所需要的基础知识 读完这部分 内容之后 你应该对 C++语言有了一些认识 但是还...

    Java版水果管理系统源码-Classical_Algorithms:算法导论

    Java版水果管理系统源码 Introduction to Algorithm 说明lgn是以2为底的对数 编译环境:g++ (Ubuntu 5.4.0-6ubuntu1~16.04.4) 5.4.0 20160609 ...算法分析 ...f(n)的值总位于c1g(n)与c2g(n)之间...快速排序及随机快速排序 Ho

    常规说明:记录cpp知识点,面试题,网络编程,多线程编程

    记录常用数据结构,包括快速排序,冒泡排序,插入排序,图,树等数据结构以及剑指offer部分变量 线性表结构 经典排序 发现 非线性结构 弦配凹凸 算法思想 动态规划,每日一练 高级算法篇 算法高级篇并发处理算法...

    java自学之道

    3.3 快速排序算法 3.4选择排序算法 3.5直接插入算法 3.6希尔排序算法 3.7 二分查找算法 3.8 二叉树 3.9 图的实现 3.10 生产者消费者的实现 3.11 银行家算法 3.12 KMP算法 3.13 RSA的实现 第4章 IO流实例开发 4.1流...

    C#开发实例大全(基础卷).软件开发技术联盟(带详细书签) PDF 下载

    实例101 使用快速排序法对一维数组进行排序 119 实例102 使用直接插入法对一维数组进行排序 121 实例103 使用希尔排序法对一维数组进行排序 122 实例104 使用Sort方法对数组进行快速排序 124 实例105 反转数组中元素...

    asp.net知识库

    .NET关于string转换的一个小Bug Regular Expressions 完整的在.net后台执行javascript脚本集合 ASP.NET 中的正则表达式 常用的匹配正则表达式和实例 经典正则表达式 delegate vs. event 我是谁?[C#] 表达式计算引擎...

    数据结构课设

    5、排序算法比较 任务 :利用随机函数产生10个样本(其中之一已为正序,之一为倒序),每个样本有20000随机整数,利用直接插入排序、希尔排序,冒泡排序、快速排序、选择排序、堆排序,归并排序(递归和非递归),...

    C/C++程序员面试指南.杨国祥(带详细书签).pdf

    第一篇 求职 第1章 应聘求职 1.1 企业与人才 1.1.1 企业需要什么样的人才 1.1.2 如何成为企业需要的人才 1.2 做好面试的准备 1.2.1 面试衣着 1.2.2 简历 1.3 面试 1.3.1 面试注意事项 1.3.2 面试问题分析 问题一:...

Global site tag (gtag.js) - Google Analytics