日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java heapsort_排序算法笔记:堆排序 HeapSort in java

發布時間:2023/12/2 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java heapsort_排序算法笔记:堆排序 HeapSort in java 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

/**

* 堆排序

* 簡述:

* 首先使用建立最大堆的算法建立好最大堆,然后將堆頂元素(最大值)與最后一個值交換,同時使得堆的長度減小1 ,調用保持最大堆性質的算法調整,使得堆頂元素成為最大值,此時最后一個元素已被排除在外

* 時間復雜度:

*Θ(nlgn)

* 空間復雜度:

*

* 優點:

*

* 缺點:

* 想著就挺麻煩的。。。相比其他排序,相對難理解一點點

* 可改進:

*

* @author CheN

*

*/

public class HeapSort {

private static int heapSize;

//左孩子編號

private static int getLeftChild(int i){

return 2 * i;

}

//右孩子編號

private static int getRightChild(int i){

return 2 * i + 1;

}

/**

* 保持最大堆的性質(孩子不分左右,均比父節點小)

* @param array,堆中的數組元素

* @param i,對以該元素為根元素的堆進行調整,假設前提:左右子樹都是最大堆

*

* 由于左右孩子都是最大堆,首先比較根元素與左右孩子,找出最大值,假如不是根元素,則調整兩個元素的值;

* 由于左孩子(右孩子)的值與根元素交換,有可能打破左子樹(右子樹)的最大堆性質,因此繼續調用,直至葉子元素。

*/

private static void maxHeapify( int[] array , int index ){

int left = getLeftChild( index );

int right = getRightChild( index );

int largest = 0;

if( left < heapSize && array[ index ] < array[ left ]){

largest = left;

}else{

largest = index;

}

if( right < heapSize && array[ right ] > array[ largest ]){

largest = right;

}

if( largest == index ){

return ;

} else {

int temp = array[ index ];

array[ index ] = array[ largest ];

array[ largest ] = temp;

maxHeapify( array, largest );

}

}

/**

* 建立最大堆。在數據中,array.length/2+1一直到最后的元素都是葉子元素,因此從其前一個元素開始,一直到第一個元素,重復調用maxHeapify函數,使其保持最大堆的性質

* @param array

*/

private static void buildMaxHeap(int[] array){

for( int i = array.length / 2 ; i >= 1; i-- ){

maxHeapify( array , i );

}

}

/**

* 堆排序:

*/

public static void asc( int[] array ){

// 找出最小元素,并將其置于array[0]

int min = array[0];

for(int i = 1 ; i < array.length ; i++ ){

if( min > array[i] ){

min = array[i];

array[i] = array[0];

array[0] = min;

}

}

//調用保持最大堆性質的算法調整,似的對應元素成為最大值,此時最后一個元素已被排除在外

heapSize = array.length;

buildMaxHeap( array );

for(int i = array.length - 1 ; i >= 2 ; i--){

int temp = array[1];

array[1] = array[i];

array[i] = temp;

heapSize--;

maxHeapify( array , 1 );

}

}

}

若有錯誤或不妥之處,敬請諒解并指點。

總結

以上是生活随笔為你收集整理的java heapsort_排序算法笔记:堆排序 HeapSort in java的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。