浅析java快速排序算法

 更新时间:2015年02月02日 10:39:23   投稿:hebedich  
这篇文章主要介绍了浅析java快速排序算法,需要的朋友可以参考下

快速排序是找出一个元素(理论上可以随便找一个)作为基准(pivot),然后对数组进行分区操作,使基准左边元素的值都不大于基准值,基准右边的元素值 都不小于基准值,如此作为基准的元素调整到排序后的正确位置。递归快速排序,将其他n-1个元素也调整到排序后的正确位置。最后每个元素都是在排序后的正 确位置,排序完成。所以快速排序算法的核心算法是分区操作,即如何调整基准的位置以及调整返回基准的最终位置以便分治递归。

一趟快速排序的算法是:

1)设置两个变量i、j,排序开始的时候:i=0,j=N-1;
2)以第一个数组元素作为关键数据,赋值给key,即key=A[0];
3)从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于key的值A[j],将A[j]和A[i]互换;
4)从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于key的A[i],将A[i]和A[j]互换;
5)重复第3、4步,直到i=j; (3,4步中,没找到符合条件的值,即3中A[j]不小于key,4中A[i]不大于key的时候改变j、i的值,使得j=j-1,i=i+1,直至找到为止。找到符合条件的值,进行交换的时候i, j指针位置不变。另外,i==j这一过程一定正好是i+或j-完成的时候,此时令循环结束)。

举例说明一下吧,这个可能不是太好理解。假设要排序的序列为

复制代码 代码如下:

package com.zc.manythread;
import java.util.Random;
/**
* 快速排序
* @author Administrator
*
*/
public class QSort {
   int [] date;
   public QSort(int[] date) {
       this.date=date;
   }
   /**
    * 交换函数
    * @param a
    * @param i
    * @param j
    */
   private void swap(int a[],int i,int j) {
       int T;
       T=a[i];
       a[i]=a[j];
       a[j]=T;
   }
   /*******************
    * 排序函数
    * @param a
    * @param lo0
    * @param hi0
    * @return
    */
   int[] QuickSort(int a[],int lo0,int hi0){//分治法,作用就是将数组分为A[lo0..q-1] 和A[q+1..hi0] 
       int lo=lo0;
       int hi=hi0;
       int mid;
       if (hi0>lo0) {
           mid=a[(hi0+lo0)/2];
           while(lo<=hi){
               while((lo<hi0)&&(a[lo]<mid))  ++lo;
               while((hi>lo0)&&(a[hi]>mid))  --hi;
               if (lo<=hi) {
                   swap(a,lo,hi);
                   ++lo;
                   --hi;
               }
           }
           if (lo0<hi) {
               QuickSort(a, lo0, hi);
           }
           if (lo<hi0) {
               QuickSort(a, lo, hi0);
           }
       }
       return a;
   }
   /**************
    *
    * 创建有重复数组数据
    * *****************/
   private static int[]  createDate(int count) {
       int[] data=new int[count];
       for (int i = 0; i < data.length; i++) {
           data[i]=(int)(Math.random()*count);
       }
       return data;
   }
   /**
    * 无重复数组数据
    * @param count
    * @return
    */
   private static int[]  createDate1(int count) {
       int[] data=new int[count];
         Random rand = new Random();
         boolean[] bool = new boolean[100];
         int num = 0;
         for (int i = 0; i < count; i++) {
          do {
           // 如果产生的数相同继续循环
           num = rand.nextInt(100);
          } while (bool[num]);
          bool[num] = true;
          data[i]=num;
         }
         return data;
   }
   /**************主函数*****************/
   public static void main(String[] args) {
       final int count=10;
       int[] data=createDate1(count);
       for (int n:data) {
           System.out.print(n+"\t");
       }
       QSort data1=new QSort(data);
       System.out.println();
       int[] a=data1.QuickSort(data,0, count-1);
       for (int n:a) {
           System.out.print(n+"\t");
       }
   }
}

结果如下:

以上就是本文所述的全部内容了,希望小伙伴们能够喜欢。

相关文章

  • Java中泛型使用的简单方法介绍

    Java中泛型使用的简单方法介绍

    这篇文章主要给大家介绍了关于Java中泛型使用的简单方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Java具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • Java反射使用的详细介绍(最新推荐)

    Java反射使用的详细介绍(最新推荐)

    这篇文章主要介绍了Java反射使用的详细介绍,反射的第一步都是先得到编译后的Class类对象,然后就可以得到Class的全部成分,本文结合实例代码详细讲解,需要的朋友可以参考下
    2023-02-02
  • Java反射,泛型在Json中的运用

    Java反射,泛型在Json中的运用

    这篇文章主要介绍了Java反射,泛型在Json中的运用,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-12-12
  • 彻底理解Java中的ThreadLocal

    彻底理解Java中的ThreadLocal

     ThreadLocal翻译成中文比较准确的叫法应该是:线程局部变量。使用这个工具类可以很简洁地编写出优美的多线程程序。 接下来通过本文给大家介绍Java中的ThreadLocal,需要的朋友可以参考下
    2017-03-03
  • Java读取网络文件的实例代码

    Java读取网络文件的实例代码

    这篇文章主要介绍了Java读取网络文件的实例代码,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • IDEA使用SequenceDiagram插件绘制时序图的方法

    IDEA使用SequenceDiagram插件绘制时序图的方法

    这篇文章主要介绍了IDEA使用SequenceDiagram插件绘制时序图的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 使用Java获取系统信息的常用代码整理总结

    使用Java获取系统信息的常用代码整理总结

    这篇文章主要介绍了使用Java获取系统信息的常用代码整理总结,在服务器端一般经常能够用到,欢迎收藏,需要的朋友可以参考下
    2015-11-11
  • 详解SpringBoot和Mybatis配置多数据源

    详解SpringBoot和Mybatis配置多数据源

    本篇文章主要介绍了详解SpringBoot和Mybatis配置多数据源,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Java WebService 简单实例(附实例代码)

    Java WebService 简单实例(附实例代码)

    本篇文章主要介绍了Java WebService 简单实例(附实例代码), Web Service 是一种新的web应用程序分支,他们是自包含、自描述、模块化的应用,可以发布、定位、通过web调用。有兴趣的可以了解一下
    2017-01-01
  • SpringMVC Mybatis配置多个数据源并切换代码详解

    SpringMVC Mybatis配置多个数据源并切换代码详解

    这篇文章主要介绍了SpringMVC Mybatis配置多个数据源并切换代码详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11

最新评论