Java实现快速排序算法的完整示例

首先,来看一下,快速排序的实现的动态图:

快速排序介绍:

快速排序,根据教科书说法来看,是冒泡排序的一种改进。

快速排序,由一个待排序的数组(array),以及找准三个变量:

  • 中枢值(pivot)
  • 左值(left)
  • 右值(right)

根据中枢值(pivot)来做调整,将数组(array)分为三个部分:

  • 第一部分:中枢值(pivot),单独数字构成,这个值在每次排序好的"最中间";
  • 第二部分:左边数组(由array的一部分组成),这个数组在第一部分 中枢值(pivot) 的"左边",其中左边数组中的每一个值(不一定是排序好的,可能是乱序的),都要比中枢值和右边数组的值要小;
  • 第三部分:右边数组(由array的一部分组成),这个数组在第一部分 中枢值(pivot)的"右边",其中右边数组的每一个值(不一定是排序好的,可能是乱序的),都要比中枢值和左边数组的值要大

以上就是快速排序要做的第一步,将数组按照:左边数组 、 中枢值 、 右边数组 区分开来。

再根据 递归思想 , 对 左边数组 、 中枢值 、 右边数组 不断递归循环操作,不断拆分出三部分来,最终达到快速排序的效果。

核心逻辑:

快排算法递归调用:

接下来附上完整实现代码:

public class QuickSort {

 /**
  * 快速排序调用方法
  *
  * @param ary 待排序数组
  * @param left 左值
  * @param right 右值
  * @return int值
  * @author Cansluck
  */
 public static int getSortNum(int[] ary, int left, int right) {
  // 定义一个中枢值pivot,让其等于数组的左值,枢轴选定后永远不变,最终在中间,前小后大
  int pivot = ary[left];
  while (left < right) {
   // 看后面ary[right] > pivot比较,如果右边数组值大于中枢值,说明不需要调整位置,则让右值(right)自减1
   while (left < right && ary[right] >= pivot) {
    right--; // 执行自减操作
   }
   // 如果上面循环不符合条件的,则说明右边数组的一个值,小于中枢值(pivot),则将其替换到左边数组中
   ary[left] = ary[right];
   // 看后面ary[left] < pivot比较,如果左边数组值小于中枢值,说明不需要调整位置,则让左值(left)自增1
   while (left < right && ary[left] <= pivot) {
    left++; // 执行自增操作
   }
   // 如果上面循环不符合条件,则说明左边数组的一个值,大于中枢值(pivot),则将其替换到右边数组中
   ary[right] = ary[left];
  }
  // 最后将中枢值给自增后的左边数组的一个值中
  ary[left] = pivot;
  // 返回左边数组下标
  return left;
 }

 /**
  * 快速排序递归方法
  *
  * @author Cansluck
  * @param ary 待排序数组
  * @param left 左值
  * @param right 右值
  */
 public static void quickSort(int[] ary, int left, int right) {
  // 定义中枢值
  int pivot;
  // 判断
  if (left < right) {
   // 根据方法得到了每次中枢值的位置
   pivot = getSortNum(ary, left, right);
   // 根据中枢值(pivot),来对左边数组进行递归调用快速排序
   quickSort(ary, left, pivot - 1);
   // 根据中枢值(pivot),来对右边数组进行递归调用快速排序
   quickSort(ary, pivot + 1, right);
  }
 }

 public static void main(String[] args) {
  int[] ary = {97, 58, 12, 88, 77, 22, 33, 44, 66, 22};
  quickSort(ary, 0, ary.length - 1);
  for (int i = 0; i < ary.length; i++) {
   if (i != ary.length - 1)
    System.out.print(ary[i] + ", ");
   else
    System.out.println(ary[i]);
  }
 }
}

以上就是快速排序的详细介绍及完整实现。有兴趣的小伙伴也自行实现以下吧~

到此这篇关于Java实现快速排序算法的文章就介绍到这了,更多相关Java实现快速排序算法内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 快速排序的深入详解以及java实现

    快速排序作为一种高效的排序算法被广泛应用,SUN的JDK中的Arrays.sort 方法用的就是快排.快排采用了经典的分治思想(divide and conquer): Divide:选取一个基元X(一般选取数组第一个元素),通过某种分区操作(partitioning)将数组划分为两个部分:左半部分小于等于X,右半部分大于等于X.Conquer: 左右两个子数组递归地调用Divide过程.Combine:快排作为就地排序算法(in place sort),不需要任何合并操作可以看出快排的核心部分

  • java 合并排序算法、冒泡排序算法、选择排序算法、插入排序算法、快速排序算法的描述

    算法是在有限步骤内求解某一问题所使用的一组定义明确的规则.通俗点说,就是计算机解题的过程.在这个过程中,无论是形成解题思路还是编写程序,都是在实施某种算法.前者是推理实现的算法,后者是操作实现的算法. 一个算法应该具有以下五个重要的特征: 1.有穷性: 一个算法必须保证执行有限步之后结束: 2.确切性: 算法的每一步骤必须有确切的定义: 3.输入:一个算法有0个或多个输入,以刻画运算对象的初始情况: 4.输出:一个算法有一个或多个输出,以反映对输入数据加工后的结果.没有输出的算法是毫无意义的:

  • java数组排序示例(冒泡排序、快速排序、希尔排序、选择排序)

    快速排序法主要是运用了Arrays中的一个方法Arrays.sort()实现. 冒泡法是运用遍历数组进行比较,通过不断的比较将最小值或者最大值一个一个的遍历出来. 选择排序法是将数组的第一个数据作为最大或者最小的值,然后通过比较循环,输出有序的数组. 插入排序是选择一个数组中的数据,通过不断的插入比较最后进行排序. 复制代码 代码如下: package com.firewolf.sort; public class MySort { /**  * @param args  */ public s

  • Java实现对两个List快速去重并排序操作示例

    本文实例讲述了Java实现对两个List快速去重并排序操作.分享给大家供大家参考,具体如下: 1:去重并排序 package twolist; import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.HashSet; import java.util.LinkedList; import java.util.List; import java.uti

  • Java中的数组排序方式(快速排序、冒泡排序、选择排序)

    1.使用JavaApi文档中的Arrays类中的sort()进行快速排序 复制代码 代码如下: import java.util.Arrays; public class TestOne{ public static void main(String [] args){ int [] array={2,0,1,4,5,8}; Arrays.sort(array);//调用Arrays的静态方法Sort进行排序,升序排列 for(int show:array){ System.out.printl

  • 图文讲解Java中实现quickSort快速排序算法的方法

    相对冒泡排序.选择排序等算法而言,快速排序的具体算法原理及实现有一定的难度.为了更好地理解快速排序,我们仍然以举例说明的形式来详细描述快速排序的算法原理.在前面的排序算法中,我们以5名运动员的身高排序问题为例进行讲解,为了更好地体现快速排序的特点,这里我们再额外添加3名运动员.实例中的8名运动员及其身高信息详细如下(F.G.H为新增的运动员): A(181).B(169).C(187).D(172).E(163).F(191).G(189).H(182) 在前面的排序算法中,这些排序都是由教练主

  • Java 快速排序(QuickSort)原理及实现代码

    快速排序(QuickSort )是常用到的效率比较高的一种排序算法,在面试过程中也经常提及.下面就详细讲解一下他的原理.给出一个Java版本的实现. 快速排序思想: 通过对数据元素集合Rn 进行一趟排序划分出独立的两个部分.其中一个部分的关键字比另一部分的关键字小.然后再分别对两个部分的关键字进行一趟排序,直到独立的元素只有一个,此时整个元素集合有序. 快速排序的过程--挖坑填数法(这是一个很形象的名称),对一个元素集合R[ low ... high ] ,首先取一个数(一般是R[low] )做

  • 快速排序算法原理及java递归实现

    快速排序 对冒泡排序的一种改进,若初始记录序列按关键字有序或基本有序,蜕化为冒泡排序.使用的是递归原理,在所有同数量级O(n longn) 的排序方法中,其平均性能最好.就平均时间而言,是目前被认为最好的一种内部排序方法 基本思想是:通过一躺排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列. 三个指针: 第一个指针称为pivotkey指针(枢轴),第二个指

  • Java编程实现快速排序及优化代码详解

    普通快速排序 找一个基准值base,然后一趟排序后让base左边的数都小于base,base右边的数都大于等于base.再分为两个子数组的排序.如此递归下去. public class QuickSort { public static <T extends Comparable<? super T>> void sort(T[] arr) { sort(arr, 0, arr.length - 1); } public static <T extends Comparabl

  • 快速排序的原理及java代码实现

    概述 快速排序是由东尼·霍尔所发展的一种排序算法.在平均状况下,排序 n 个项目要Ο(nlogn)次比较.事实上,快速排序通常明显比其他Ο(nlogn) 算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来,并且在大部分真实世界的数据,可以决定设计的选择,减少所需时间的二次方项之可能性. 快速排序,通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,然后分别对这两部分记录继续进行排序,以达到整个序列有序的目的. 形象图示:

随机推荐