激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語(yǔ)言 - JAVA教程 - JAVA算法起步之快速排序?qū)嵗?

JAVA算法起步之快速排序?qū)嵗?/h1>

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

這篇文章主要介紹了JAVA算法起步之快速排序?qū)嵗?需要的朋友可以參考下

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

 

復(fù)制代碼代碼如下:

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]);
  }
 }
}

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 婷婷亚洲一区二区三区 | 欧美人一级淫片a免费播放 久久99精品久久久久久园产越南 | 欧美久久久一区二区三区 | 福利免费在线观看 | 精品国产一区二区三区久久久蜜月 | 多人乱大交xxxxx变态 | 一级毛片在线免费观看 | 日本网站一区二区三区 | 久久久看 | 免费黄色一级片 | 精品国产一区二区三区四区在线 | 天天夜夜操操 | 成人精品久久久 | www.91sese| 高清一区二区在线观看 | 久久久久久久久久网 | 欧美不卡三区 | 国产精品一区免费在线观看 | 国产亚洲精品久久久久久久 | 在线免费日本 | gogo全球大胆高清人露出91 | 亚洲看片网| 99精品国产成人一区二区 | 亚洲无马在线观看 | 欧美日韩经典在线 | 毛片视频观看 | 国产伦精品一区二区三区 | 成人免费毛片一 | 精品国产91久久久久久 | 久久成年网站 | 成人在线视频免费 | 一区二区三区日韩 | 青青草最新网址 | 久久99国产精品久久99 | 国产一级在线看 | 国产色片 | 色柚视频网站ww色 | 久久精品一区二区三 | 免费国产 | 天堂成人一区二区三区 | 日韩视频在线不卡 |