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

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

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

服務器之家 - 編程語言 - JAVA教程 - JAVA算法起步之快速排序實例

JAVA算法起步之快速排序實例

2019-11-06 11:25java教程網(wǎng) JAVA教程

這篇文章主要介紹了JAVA算法起步之快速排序實例,需要的朋友可以參考下

快速排序一聽這個名字可能感覺很快,但是他的算法時間復雜度最壞情況卻跟插入排序是一樣的。之所以成為快速排序是因為他的平均效率比堆排序還要快,快速排序也是基于分治思想與歸并排序差不多,但是快速排序是原址的,直接在原數(shù)組操作不需要再開辟新的存儲空間。快速排序的思想很簡單,就是選定一個關鍵字k將原數(shù)組分成兩份g1與g2,g1中所有的元素都比k小或者相等,而g2中所有的數(shù)據(jù)都比k大或者等于,這樣對g1與g2分別進行快速排序,最終我們得到的就是一個有序的數(shù)組。代碼中的sort方法就是對剛才語句的描述。而關鍵的算法就是去尋找k的位置將原數(shù)組分為大小兩部分的過程。方法getPlocation就是快速排序的核心。他的實現(xiàn)原理有點像插入排序只是有點像。每次都把map中end位置的元素作為關鍵字,通過與end元素對比將數(shù)組分成大小兩部分,而i與j則是兩個分割線,i與j之間的數(shù)都是比core大的元素,i與j就像一條貪吃蛇,當j的下一個數(shù)比core大的時候j+1,i到j的長度增大了,而如果比core小的話,i與j都向前走一下,并將那個小數(shù)放在i的前面。這樣循環(huán)一遍后,start到end-1之間就是按大小分開的,最后將core放在中間,將core的位置返回就是分界線了。

 

復制代碼代碼如下:

public class QuickSort {
 public int getPlocation(int[] map,int start,int end){
  int core=map[end];
  int i=start-1;
  for(int j=start;j<=end-1;j++){
   if(map[j]<=core){
    i++;
    int cache=map[j];
    map[j]=map[i];
    map[i]=cache;
   }
  }
  i++;
  map[end]=map[i];
  map[i]=core;
  return i;
 }
 public void sort(int[] map,int start,int end){
  if(start<end){
  int p=getPlocation(map, start, end);
  sort(map, start, p-1);
  sort(map,p+1,end);
  }
 }
 public static void main(String[] args) {
  int[] map=new int[]{4,1,5,3,7,12,65,7};
  QuickSort qs=new QuickSort();
  qs.sort(map, 0, map.length-1);
  for (int i = 0; i < map.length; i++) {
   System.out.println(map[i]);
  }
 }
}

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久天堂成人影院 | 无人区在线观看免费视频国语 | 小寡妇好紧进去了好大看视频 | 青青草原手机在线视频 | 天堂色 | 喜欢老头吃我奶躁我的动图 | 女人与d0gxxx| 欧美老少 | 视频在线观看入口一二三2021 | 久久婷婷五月综合色丁香 | 天天干天天爽天天操 | 三年片韩国在线 | 国产成人综合亚洲亚洲欧美 | 嫩草香味| 欧美性理论片在线观看片免费 | 精品国产91高清在线观看 | 玩两个少妇女邻居 | 久草在线福利视频在线播放 | 千金肉奴隶免费观看 | 无码日韩精品一区二区免费 | 成人免费视频在 | 黄瓜视频黄版 | 欧美极品摘花过程 | 国产白虎 | 午夜AV国产欧美亚洲高清在线 | 国外欧美一区另类中文字幕 | 久久全国免费久久青青小草 | 欧美成人tv在线观看免费 | 男人操美女逼视频 | 免费二区 | 操老逼视频 | 国产精品美女久久久久网站 | 欧美生活一级片 | 毛片手机在线视频免费观看 | 成人看片免费无限观看视频 | 亚洲国产午夜 | 免费视频网 | 婷婷伊人综合亚洲综合网 | 欧美亚洲国产另类在线观看 | 884hutv四虎永久7777 | 忘忧草在线社区WWW日本直播 |