template<typename T>
void maxHeapify(T arr[], int index, int heapSize) {
int maxIndex = index;
int left = 2 * index + 1;
int right = left + 1;
if (left < heapSize && arr[index] < arr[left]) {
maxIndex = left;
}
if (right < heapSize && arr[maxIndex] < arr[right]) {
maxIndex = right;
}
if (maxIndex != index) {
swap(arr[maxIndex], arr[index]);
maxHeapify(arr, maxIndex, heapSize);
}
return;
}
template<typename T>
void build(T arr[], int heapSize) {
for (int i = heapSize / 2 - 1; i >= 0; i--) {
maxHeapify(arr, i, heapSize);
}
}
template<typename T>
void sort(T arr[], int heapSize) {
build(arr, heapSize);
for (int i = heapSize - 1; i > 0; i--) {
swap(arr[0], arr[i]);
maxHeapify(arr, 0, i);
}
}
template<typename T>
void swap(T &a, T &b) {
T temp = a;
a = b;
b = temp;
}
C++的堆排序
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門掷漱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)粘室,“玉大人,你說(shuō)我怎么就攤上這事卜范∠瓮常” “怎么了?”我有些...
- 文/不壞的土叔 我叫張陵海雪,是天一觀的道長(zhǎng)锦爵。 經(jīng)常有香客問(wèn)我,道長(zhǎng)喳魏,這世上最難降的妖魔是什么棉浸? 我笑而不...
- 正文 為了忘掉前任,我火速辦了婚禮刺彩,結(jié)果婚禮上迷郑,老公的妹妹穿的比我還像新娘。我一直安慰自己创倔,他們只是感情好嗡害,可當(dāng)我...
- 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著畦攘,像睡著了一般霸妹。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上知押,一...
- 那天叹螟,我揣著相機(jī)與錄音鹃骂,去河邊找鬼。 笑死罢绽,一個(gè)胖子當(dāng)著我的面吹牛畏线,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播良价,決...
- 文/蒼蘭香墨 我猛地睜開眼寝殴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了明垢?” 一聲冷哼從身側(cè)響起蚣常,我...
- 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎痊银,沒想到半個(gè)月后抵蚊,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡曼验,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年泌射,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鬓照。...
- 正文 年R本政府宣布臭猜,位于F島的核電站躺酒,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏蔑歌。R本人自食惡果不足惜羹应,卻給世界環(huán)境...
- 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望次屠。 院中可真熱鬧园匹,春花似錦、人聲如沸劫灶。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)本昏。三九已至供汛,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背怔昨。 一陣腳步聲響...
- 正文 我出身青樓岸啡,卻偏偏與公主長(zhǎng)得像原叮,于是被迫代替她去往敵國(guó)和親赫编。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- 上一篇C++基礎(chǔ)入門之模板堆排序(上):模板上的list的創(chuàng)造與操作 其實(shí)接下來(lái)就很簡(jiǎn)單了奋隶,只要把大眾版的堆排序翻...
- 一唯欣、堆的概念 概念:堆作為一種數(shù)據(jù)結(jié)構(gòu)是一種完全二叉樹嘹吨。所謂完全二叉樹,可能有些書本有很晦澀難懂的概念境氢。就我的理解...
- 選擇排序 對(duì)于任何輸入墨微,時(shí)間為O(n*n); 冒泡排序 最優(yōu)(對(duì)于升序的數(shù)組扁掸,因?yàn)榧尤肓艘粋€(gè)跳出判斷):O(n)翘县,...
- 整段源碼鏈接C++的模板元堆排序 要點(diǎn) 組建數(shù)據(jù)結(jié)構(gòu)list 組建對(duì)list的各種基本操作 堆排序中組建堆排序個(gè)個(gè)...
- 漂泊的船 最懷念無(wú)風(fēng)浪的港灣 卻從不作過(guò)久的停留 它害怕生銹 年輕的浪子 常夢(mèng)見母親的呢喃 但只字不提 他擔(dān)憂滿腔...