欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

深入淺析java中堆排序的原理

本篇文章為大家展示了深入淺析java中堆排序的原理,內(nèi)容簡(jiǎn)明扼要并且容易理解,絕對(duì)能使你眼前一亮,通過(guò)這篇文章的詳細(xì)介紹希望你能有所收獲。

公司主營(yíng)業(yè)務(wù):成都網(wǎng)站設(shè)計(jì)、網(wǎng)站制作、外貿(mào)營(yíng)銷網(wǎng)站建設(shè)、移動(dòng)網(wǎng)站開(kāi)發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開(kāi)放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)公司推出洪山免費(fèi)做網(wǎng)站回饋大家。

從堆排序的簡(jiǎn)介到堆排序的算法實(shí)現(xiàn)等如下:

1. 簡(jiǎn)介

堆排序是建立在堆這種數(shù)據(jù)結(jié)構(gòu)基礎(chǔ)上的選擇排序,是原址排序,時(shí)間復(fù)雜度O(nlogn),堆排序并不是一種穩(wěn)定的排序方式。堆排序中通常使用的堆為最大堆。

2. 堆的定義

堆是一種數(shù)據(jù)結(jié)構(gòu),是一顆特殊的完全二叉樹(shù),通常分為最大堆最小堆。最大堆的定義為根結(jié)點(diǎn)最大,且根結(jié)點(diǎn)左右子樹(shù)都是最大堆;同樣,最小堆的定義為根結(jié)點(diǎn)最小,且根結(jié)點(diǎn)左右子樹(shù)均為最小堆。

最大堆滿足其每一個(gè)父結(jié)點(diǎn)均大于其左右子結(jié)點(diǎn),最小堆則滿足其每一個(gè)父結(jié)點(diǎn)均小于其左右子結(jié)點(diǎn)。

3. 堆排序

3.1 堆的存放

在堆排序中,堆所表示的二叉樹(shù)并不需要使用指針的方式在計(jì)算機(jī)中存放,只需要使用數(shù)組即可,將樹(shù)的結(jié)點(diǎn),從上至下,從左至右一個(gè)個(gè)放到數(shù)組中去。

   因此,如果數(shù)組的起始索引為0,對(duì)于一個(gè)結(jié)點(diǎn)i來(lái)說(shuō),它的父結(jié)點(diǎn)索引為⌊i/2⌋,它的左子結(jié)點(diǎn)索引為2i+1,右子結(jié)點(diǎn)索引為2i+2。最后一個(gè)非葉子節(jié)點(diǎn)就是最后一個(gè)結(jié)點(diǎn)的父親,如果數(shù)組長(zhǎng)度為n,那么其索引為⌊(n-1)/2⌋。

3.2 堆排序主要步驟

將無(wú)序序列構(gòu)建成最大堆

將數(shù)組分成兩個(gè)區(qū)域,有序區(qū)和無(wú)序區(qū),初始時(shí)創(chuàng)建一個(gè)整數(shù)i為數(shù)組的長(zhǎng)度,用來(lái)劃分有序區(qū)和無(wú)序區(qū),有序區(qū)初始為空。

將堆頂元素和最后一個(gè)無(wú)序區(qū)的元素交換,然后i-1。

調(diào)整使得所有無(wú)序區(qū)的元素重新為最大堆。

重復(fù)3,4步,直到 i = 0

3.3 堆的調(diào)整

假設(shè)有某棵完全二叉樹(shù),其左右子樹(shù)均為最大堆,如何調(diào)整使得該二叉樹(shù)成為最大堆呢?如果根結(jié)點(diǎn)大于左右子結(jié)點(diǎn),那么已經(jīng)是最大堆了,無(wú)需調(diào)整。否則,交換根結(jié)點(diǎn)和左右子結(jié)點(diǎn)中較大的那個(gè)。假設(shè)交換的是左結(jié)點(diǎn),那么目前這棵完全二叉樹(shù)右子樹(shù)仍然是一個(gè)最大堆,左子樹(shù)則不一定,但是左子樹(shù)的左右子樹(shù)還是最大堆,因此不斷遞歸下去調(diào)整即可。

   因此,交換最后一個(gè)元素和堆頂元素后的調(diào)整步驟,就和上面所說(shuō)的一致。而將無(wú)序序列構(gòu)建成最大堆,同樣也可以運(yùn)用這一點(diǎn)。從最后一個(gè)非葉子結(jié)點(diǎn)到第一個(gè)非葉子結(jié)點(diǎn)(根結(jié)點(diǎn)),對(duì)這些結(jié)點(diǎn)作為根結(jié)點(diǎn)的子樹(shù),按順序調(diào)用一次上述描述的調(diào)整即可(每次調(diào)用時(shí),該子樹(shù)的左右子樹(shù)必定是最大堆)。

4. 算法實(shí)現(xiàn)

#include <stdio.h>
void swap(int *a,int *b) {
 int temp = *a;
 *a = *b;
 *b = temp;
}
//左右子樹(shù)都是最大堆,從上至下調(diào)整使得最大堆, root_index是要調(diào)整的樹(shù)的根節(jié)點(diǎn),length是無(wú)序區(qū)的長(zhǎng)度
void adjust(int array[],int root_index,int length) {
 int left_child = root_index*2+1;
 int right_child = left_child+1;
 int left_or_right = 0;
 if((left_child >= length && right_child >= length) || (left_child >= length && array[root_index] >= array[right_child]) ||
 (right_child >= length && array[root_index] >= array[left_child]) || (array[root_index] >= array[left_child] && array[root_index] >= array[right_child])){
  return;
 }
 else if (array[left_child] >= array[root_index] && (right_child >= length || array[left_child] >= array[right_child])) {
  left_or_right = 1;
 }
 else if (array[right_child] >= array[root_index] && (left_child >= length || array[right_child] >= array[left_child])) {
  left_or_right = 0;
 }
 if(left_or_right) {
  swap(&array[left_child],&array[root_index]);
  adjust(array,left_child,length);
 }
 else {
  swap(&array[right_child],&array[root_index]);
  adjust(array,right_child,length);  
 }
}
//heapsort主遞歸,每一次將無(wú)序區(qū)最后一個(gè)元素與堆頂元素交換,將堆頂元素加入有序區(qū),因此有序區(qū)加1,無(wú)序區(qū)減1,無(wú)序區(qū)只剩一個(gè)元素的時(shí)候遞歸終止
void heapsort_main(int array[],int length,int last_index) {
 int i;
 if(last_index == 0)
  return;
 swap(&array[0],&array[last_index]);
 adjust(array,0,last_index);
 heapsort_main(array,length,last_index-1);
} 
//入口函數(shù),array是待排序的數(shù)組,length是其長(zhǎng)度
void heapsort(int array[],int length) {
 int i;
 for(i = length/2-1;i >= 0;i--) {
  adjust(array,i,length);
 }
 heapsort_main(array,length,length-1);
}
int main(int argc,char *argv[]) {
 int array[9] = {1,1,1,2,3,5,2,3,5};
 heapsort(array,9);
 int i;
 for(i = 0;i < 9;i++) {
  printf("%d ",array[i]);
 }
}

5.堆排序性質(zhì)

時(shí)間復(fù)雜度O(nlogn)

空間復(fù)雜度O(1)

不穩(wěn)定排序

上述內(nèi)容就是深入淺析java中堆排序的原理,你們學(xué)到知識(shí)或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識(shí)儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前標(biāo)題:深入淺析java中堆排序的原理
文章鏈接:http://chinadenli.net/article42/ppijec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作App設(shè)計(jì)、關(guān)鍵詞優(yōu)化云服務(wù)器、全網(wǎng)營(yíng)銷推廣靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司