成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

LintCode中堆化的示例分析

這篇文章將為大家詳細講解有關(guān)LintCode中堆化的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)主要從事成都網(wǎng)站建設(shè)、網(wǎng)站制作、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務棗莊,十年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220

LintCode 堆化詳解及實例代碼

給出一個整數(shù)數(shù)組,堆化操作就是把它變成一個最小堆數(shù)組。

對于堆數(shù)組A,A[0]是堆的根,并對于每個A[i],A [i * 2 + 1]是A[i]的左兒子并且A[i * 2 + 2]是A[i]的右兒子。

樣例

給出 [3,2,1,4,5],返回[1,2,3,4,5] 或者任何一個合法的堆數(shù)組

挑戰(zhàn)

O(n)的時間復雜度完成堆化

說明

什么是堆?

堆是一種數(shù)據(jù)結(jié)構(gòu),它通常有三種方法:push, pop 和 top。其中,“push”添加新的元素進入堆,“pop”刪除堆中最小/最大元素,“top”返回堆中最小/最大元素。

什么是堆化?

把一個無序整數(shù)數(shù)組變成一個堆數(shù)組。如果是最小堆,每個元素A[i],我們將得到A[i * 2 + 1] >= A[i]和A[i  * 2 + 2] >= A[i]
如果有很多種堆化的結(jié)果?

返回其中任何一個。

分析:一開始想到堆化么肯定就是堆排序吧,粗粗一想貌似復雜度是O(nlgn),后來參考該文章才知道O(nlgn)是復雜度上限,平均是O(n)

代碼:

class Solution { 
public: 
  /** 
   * @param A: Given an integer array 
   * @return: void 
   */ 
  void heapify(vector<int> &A) { 
    // write your code here 
    int n = A.size()-1; 
    for(int i=n/2;i>=0;i--) 
      heapify(A,i); 
  } 
  void heapify(vector<int> &A,int i) 
  { 
    int l = 2*i+1; 
    int r = 2*i+2; 
    int smallest = i; 
    if(l<A.size()&&A[l]<A[smallest]) 
      smallest = l; 
    if(r<A.size()&&A[r]<A[smallest]) 
      smallest = r; 
    if(smallest!=i) 
    { 
      swap(A[i],A[smallest]); 
      heapify(A,smallest); 
    } 
  } 
};

關(guān)于“LintCode中堆化的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

文章標題:LintCode中堆化的示例分析
本文URL:http://jinyejixie.com/article2/pgihic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務器、App開發(fā)品牌網(wǎng)站設(shè)計、營銷型網(wǎng)站建設(shè)、服務器托管、網(wǎng)站制作

廣告

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

h5響應式網(wǎng)站建設(shè)
隆回县| 河西区| 漠河县| 泾川县| 内乡县| 天等县| 香格里拉县| 浦江县| 临安市| 洛隆县| 远安县| 清水县| 巴塘县| 长乐市| 丘北县| 盘山县| 滁州市| 中山市| 图木舒克市| 广饶县| 凉山| 赣榆县| 玉溪市| 木里| 苏尼特右旗| 四会市| 加查县| 镇雄县| 汉沽区| 成都市| 栾城县| 永寿县| 长顺县| 九江县| 洪泽县| 青铜峡市| 闵行区| 庆城县| 新乡县| 原平市| 临夏县|