一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 淺析java快速排序算法

淺析java快速排序算法

2019-12-09 14:29hebedich JAVA教程

這篇文章主要介紹了淺析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-完成的時候,此時令循環結束)。

舉例說明一下吧,這個可能不是太好理解。假設要排序的序列為

淺析java快速排序算法

 

復制代碼代碼如下:

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快速排序算法

以上就是本文所述的全部內容了,希望小伙伴們能夠喜歡。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 亚洲热在线视频 | 久久久精品日本一区二区三区 | 香蕉视频久久 | 三级全黄裸体 | 欧美日韩一二三区免费视频观看 | 午夜理论电影在线观看亚洲 | 久久天天综合 | 免费观看的毛片 | 变态np虐高h | 女教师系列三上悠亚在线观看 | 高清一级片 | 国产精品永久免费自在线观看 | 楚乔传第二部免费观看全集完整版 | 国产成人啪精品午夜在线观看 | 农村妇女野外性生话免费视频 | 国产日韩欧美视频 | 亚洲福利在线观看 | 欧美日韩第二页 | 小泽玛丽av无码观看 | 丝瓜香蕉视频 | 国产nv精品你懂得 | 亚洲天堂视频在线观看 | 九九精品视频在线观看九九 | 污书屋| 美女尿口照片 | 91天堂素人97年清纯嫩模 | 成人高清视频在线观看 | 午夜福到在线4国产 | 欧美日韩视频在线一区二区 | 五月色天在线视频综合观看 | 国产90后美女露脸在线观看 | 女人把扒开给男人爽 | 亚洲AV人无码综合在线观看蜜桃 | 九九精品99久久久香蕉 | 我要看逼| 日韩精品福利视频一区二区三区 | 国语自产拍在线观看7m | 亚洲无线一二三四区 | 欧洲vodafonewi喷潮 | 国语精彩对白2021 | 精品国产欧美一区二区 |