新聞中心
本篇內(nèi)容介紹了“PHP SPL標準庫之?dāng)?shù)據(jù)結(jié)構(gòu)堆SplHeap的使用方法”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!
堆(Heap)就是為了實現(xiàn)優(yōu)先隊列而設(shè)計的一種數(shù)據(jù)結(jié)構(gòu),它是通過構(gòu)造二叉堆(二叉樹的一種)實現(xiàn)。根節(jié)點較大的堆叫做較大堆或大根堆,根節(jié)點最小的堆叫做最小堆或小根堆。二叉堆還常用于排序(堆排序)。
如下:最小堆(任意節(jié)點的優(yōu)先級不小于它的子節(jié)點)
看看PHP SplHeap的實現(xiàn):
顯然它是一個抽象類,較大堆(SplMaxHeap)和最小堆(SplMinHeap)就是繼承它實現(xiàn)的。較大堆和最小堆并沒有額外的方法
SplHeap的簡單使用如下:
class MySimpleHeap extends SplHeap { //compare()方法用來比較兩個元素的大小,絕對他們在堆中的位置 public function compare( $value1, $value2 ) { return ( $value1 - $value2 ); } } $obj = new MySimpleHeap(); $obj->insert( 4 ); $obj->insert( 8 ); $obj->insert( 1 ); $obj->insert( 0 ); echo $obj->top(); //8 echo $obj->count(); //4 foreach( $obj as $number ) { echo $number; }
“PHP SPL標準庫之?dāng)?shù)據(jù)結(jié)構(gòu)堆SplHeap的使用方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
名稱欄目:PHPSPL標準庫之?dāng)?shù)據(jù)結(jié)構(gòu)堆SplHeap的使用方法-創(chuàng)新互聯(lián)
當(dāng)前URL:http://www.dlmjj.cn/article/doedoj.html