青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 200, comments - 8, trackbacks - 0, articles - 0

最小堆&&最大堆的實現(c++)(轉)

Posted on 2012-11-19 21:09 鑫龍 閱讀(1221) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構與算法
最小堆:
template<class T>
class MinHeap {
public:
    MinHeap(
int MinHeapSize = 10);
    
~MinHeap() {delete [] heap;}
    
int Size() const {return CurrentSize;}
    T Min() {
if (CurrentSize == 0)
              
throw OutOfBounds();
           
return heap[1];}
    MinHeap
<T>& Insert(const T& x);
    MinHeap
<T>& DeleteMin(T& x);
    
void Initialize(T a[], int size, int ArraySize);
    
void Deactivate() {heap = 0;}
    
void Output() const;
private:
    
int CurrentSize, MaxSize;
    T 
*heap;
};

template
<class T>
MinHeap
<T>::MinHeap(int MinHeapSize)
{
    MaxSize 
= MinHeapSize;
    heap 
= new T[MaxSize+1];
    CurrentSize 
= 0;
}

template
<class T>
MinHeap
<T>& MinHeap<T>::Insert(const T& x)
{
    
if (CurrentSize == MaxSize)
        
throw NoMem();

    
//為x尋找應插入的位置
    
//i從新的葉節點開始,并沿著樹上升
    int i = ++CurrentSize;
    
while (i != 1 && x < heap[i/2]) 
    {
        heap[i] 
= heap[i/2]; // 將元素下移
        i /= 2;                 // 移向父節點
    }
    heap[i] 
= x;

    
return *this;
}

template
<class T>
MinHeap
<T>& MinHeap<T>::DeleteMin(T& x)
{
    
if (CurrentSize == 0)
        
throw OutOfBounds();

    x 
= heap[1];

    T y 
= heap[CurrentSize--]; //最后一個元素

    
// 從根開始, 為y尋找合適的位置
    int i = 1,  // 堆的當前節點
       ci = 2;    // i的子節點

    
while (ci <= CurrentSize) 
    {
        
// 使heap[ci] 是i較小的子節點
        if (ci < CurrentSize 
          
&& heap[ci] > heap[ci+1]) 
            ci
++;

        
// 能把y放入heap[i]嗎?
        if (y <= heap[ci]) 
            
break;  // 能

        
// 不能
        heap[i] = heap[ci]; // 子節點上移
        i = ci;                // 下移一層
        ci *= 2;
    }

    heap[i] 
= y;

    
return *this;
}

template
<class T>
void MinHeap<T>::Initialize(T a[], int size, int ArraySize)
{
   delete [] heap;
   heap 
= a;
   CurrentSize 
= size;
   MaxSize 
= ArraySize;

   
// 產生一個最小堆
   for (int i = CurrentSize/2; i >= 1; i--
   {
        T y 
= heap[i]; // 子樹的根

        
// 尋找放置y的位置
        int c = 2*i; // c 的父節點是y的目標位置

        
while (c <= CurrentSize) 
        {
            
// 使heap[c]是較小的子節點
            if (c < CurrentSize &&
             heap[c] 
> heap[c+1]) c++;

            
// 能把y放入heap[c/2]嗎?
            if (y <= heap[c]) break;  // 能

            
// 不能
            heap[c/2= heap[c]; // 子節點上移
            c *= 2;              // 下移一層
        }

        heap[c
/2= y;
    }
}

template
<class T>
void MinHeap<T>::Output() const
{
    cout 
<< "The " << CurrentSize
        
<< " elements are"<< endl;
    
for (int i = 1; i <= CurrentSize; i++)
      cout 
<< heap[i] << ' ';
    cout 
<< endl;
}


最大堆:
template<class T>
class MaxHeap {
public:
    MaxHeap(
int MaxHeapSize = 10);
    
~MaxHeap() {delete [] heap;}
    
int Size() const {return CurrentSize;}
    T Max() {
if (CurrentSize == 0)
              
throw OutOfBounds();
           
return heap[1];}
    MaxHeap
<T>& Insert(const T& x);
    MaxHeap
<T>& DeleteMax(T& x);
    
void Initialize(T a[], int size, int ArraySize);
    
void Deactivate() {heap = 0;}
    
void Output() const;
private:
    
int CurrentSize, MaxSize;
    T 
*heap;
};

template
<class T>
MaxHeap
<T>::MaxHeap(int MaxHeapSize)
{
    MaxSize 
= MaxHeapSize;
    heap 
= new T[MaxSize+1];
    CurrentSize 
= 0;
}

template
<class T>
MaxHeap
<T>& MaxHeap<T>::Insert(const T& x)
{
    
if (CurrentSize == MaxSize)
        
throw NoMem();

    
//為x尋找應插入的位置
    
//i從新的葉節點開始,并沿著樹上升
    int i = ++CurrentSize;
    
while (i != 1 && x > heap[i/2]) 
    {
        heap[i] 
= heap[i/2]; // 將元素下移
        i /= 2;              // 移向父節點
    }

    heap[i] 
= x;
    
return *this;
}

template
<class T>
MaxHeap
<T>& MaxHeap<T>::DeleteMax(T& x)
{
    
if (CurrentSize == 0)
        
throw OutOfBounds();

    x 
= heap[1];


    T y 
= heap[CurrentSize--]; //最后一個元素

    
// 從根開始, 為y尋找合適的位置
    int i = 1,  // 堆的當前節點
       ci = 2;    // i的子節點

    
while (ci <= CurrentSize)
    {
        
// 使heap[ci] 是i較大的子節點
        if (ci < CurrentSize 
         
&& heap[ci] < heap[ci+1]) 
            ci
++;

        
// 能把y放入heap[i]嗎?
        if (y >= heap[ci]) 
            
break;//

        
//不能
        heap[i] = heap[ci]; // 子節點上移
        i = ci;             // 下移一層
        ci *= 2;
    }

    heap[i] 
= y;

    
return *this;
}

template
<class T>
void MaxHeap<T>::Initialize(T a[], int size, int ArraySize)
{
    delete [] heap;
    heap 
= a;
    CurrentSize 
= size;
    MaxSize 
= ArraySize;

    
// 產生一個最大堆
    for (int i = CurrentSize/2; i >= 1; i--
    {
        T y 
= heap[i]; // 子樹的根

        
// 尋找放置y的位置
        int c = 2*i; // c 的父節點是y的目標位置
                
        
while (c <= CurrentSize) 
        {
            
// 使heap[c]是較大的子節點
            if (c < CurrentSize 
             
&& heap[c] < heap[c+1])
                c
++;

            
// 能把y放入heap[c/2]嗎?
            if (y >= heap[c]) 
                
break;  // 能

            
// 不能
            heap[c/2= heap[c]; // 子節點上移
            c *= 2;                 // 下移一層
        }
        heap[c
/2= y;
    }
}

template
<class T>
void MaxHeap<T>::Output() const
{
   cout 
<< "The " << CurrentSize 
        
<< " elements are"<< endl;
   
for (int i = 1; i <= CurrentSize; i++)
       cout 
<< heap[i] << ' ';
   cout 
<< endl;
}

Feedback

# re: 最小堆&&最大堆的實現(c++)(轉)[未登錄]  回復  更多評論   

2014-04-04 09:47 by ccc
錯誤也太多了吧。
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲另类春色国产| 国产精品青草久久久久福利99| 欧美不卡在线视频| 免费在线亚洲| 亚洲国产日韩在线一区模特| 久久精品国产免费| 亚洲人体影院| 亚洲午夜在线视频| 久久精品在线观看| 欧美国产专区| 黄色小说综合网站| av成人手机在线| 亚洲视频axxx| 久久国产精品99久久久久久老狼| 久久久九九九九| 在线观看国产日韩| 国产一区二区三区不卡在线观看 | 国产午夜久久久久| 好吊色欧美一区二区三区四区 | 亚洲一区二区三区在线视频| 欧美亚洲视频一区二区| 欧美成人蜜桃| 亚洲一区二区三区免费观看 | 狠狠88综合久久久久综合网| 亚洲视频播放| 久久一区二区精品| 亚洲经典自拍| 久久精品一区蜜桃臀影院 | 欧美精品久久久久久久久久| 国产精品国内视频| 亚洲美女淫视频| 亚洲欧美色婷婷| 亚洲韩国青草视频| 久久久蜜桃精品| 国产日韩欧美综合一区| 99精品免费| 欧美国产精品专区| 毛片一区二区| 午夜影院日韩| 国产精品日本精品| 亚洲日本中文字幕免费在线不卡| 久久av一区二区三区| 亚洲区中文字幕| 免费在线成人av| 亚洲免费不卡| 免费在线成人av| 欧美综合二区| 国产欧美日韩专区发布| 亚洲性图久久| 亚洲精品在线视频观看| 免费中文字幕日韩欧美| 在线观看久久av| 麻豆精品精华液| 久久女同精品一区二区| 国产精品视频第一区| aa级大片欧美| 欧美区视频在线观看| 亚洲精品国产精品国产自| 一区免费视频| 欧美不卡在线视频| 久久夜色精品国产亚洲aⅴ| 国产综合色一区二区三区| 久久久999精品免费| 欧美一级在线播放| 亚洲黄色片网站| 亚洲精品午夜精品| 欧美日本免费| 亚洲欧美视频在线观看| 亚洲亚洲精品三区日韩精品在线视频 | 久久综合久久综合久久综合| 性欧美video另类hd性玩具| 国产日韩欧美二区| 久久久久国产精品www| 久久精品国产一区二区三| 在线观看国产日韩| 亚洲精品免费在线观看| 99av国产精品欲麻豆| 国产精品伦一区| 久久久久久亚洲精品杨幂换脸| 久久成人这里只有精品| 亚洲人被黑人高潮完整版| 亚洲人成网站色ww在线| 亚洲大片在线观看| 亚洲全部视频| 国产精品永久免费视频| 久久影院午夜片一区| 久久精品二区三区| 狠狠入ady亚洲精品| 欧美黑人在线播放| 国产精品www994| 美女黄毛**国产精品啪啪| 欧美精品一卡| 久久精品国产亚洲一区二区三区| 久久美女性网| 亚洲欧美在线视频观看| 久久全国免费视频| 午夜精品久久久久久99热| 免费日韩av片| 欧美午夜精品一区二区三区| 久久久久久久久久久久久9999| 裸体一区二区| 欧美在线观看视频一区二区| 免费久久99精品国产| 欧美怡红院视频| 亚洲欧美欧美一区二区三区| 久久综合九色综合网站| 欧美小视频在线观看| 欧美国产第一页| 国产偷国产偷亚洲高清97cao| 亚洲国产精品传媒在线观看 | 亚洲第一精品福利| 亚洲美女啪啪| 亚洲黑丝在线| 久久精品成人| 午夜在线视频观看日韩17c| 亚洲国产精品综合| 狠狠色综合网| 亚洲动漫精品| 在线观看亚洲a| 欧美一级片在线播放| 亚洲一区图片| 亚洲高清视频的网址| 亚洲专区一二三| 夜久久久久久| 欧美激情视频给我| 亚洲国产日韩欧美在线图片| 在线成人免费视频| 久久久青草青青国产亚洲免观| 欧美在线视频一区| 国产精品免费视频xxxx | 久久成人18免费观看| 午夜欧美不卡精品aaaaa| 欧美日韩精品一区二区在线播放 | 久久成人免费网| 国产精品蜜臀在线观看| 中文国产成人精品| 亚洲欧美精品伊人久久| 国产精品jizz在线观看美国| 欧美 日韩 国产在线| 欧美亚洲一级片| 国产精品日产欧美久久久久| 一区二区免费在线播放| 亚洲制服av| 韩日视频一区| 国产精品99久久久久久白浆小说 | 欧美不卡高清| 亚洲欧洲日本专区| 国产精品99久久不卡二区| 欧美日韩1080p| 亚洲视频在线观看网站| 香蕉久久夜色精品国产| 韩国福利一区| 亚洲伦理在线观看| 亚洲欧美bt| 国内精品亚洲| 欧美激情无毛| 中日韩美女免费视频网址在线观看 | 性色av一区二区三区红粉影视| 午夜精品久久久久久久99樱桃 | 欧美成人精品在线观看| 亚洲人成毛片在线播放女女| 欧美久久视频| 亚洲制服av| 免费欧美日韩国产三级电影| 欧美成人精品高清在线播放| 久久久水蜜桃av免费网站| 亚洲高清不卡一区| 欧美色区777第一页| 欧美中文在线视频| 亚洲黄色影院| 午夜在线一区二区| 久久爱www.| 亚洲第一福利在线观看| 欧美日韩免费高清一区色橹橹| 亚洲在线成人| 亚洲国产精品久久久| 香蕉久久精品日日躁夜夜躁| 伊人男人综合视频网| 欧美三级中文字幕在线观看| 久久精品99无色码中文字幕| 亚洲精品四区| 免费永久网站黄欧美| 香蕉成人久久| 一二三四社区欧美黄| 国内外成人免费视频| 欧美日韩美女一区二区| 久久久亚洲成人| 亚洲综合欧美| 日韩午夜免费视频| 日韩视频一区二区| 国语自产精品视频在线看一大j8 | 欧美高潮视频| 欧美一区免费视频| 一区二区三区久久网| 欧美激情五月| 毛片一区二区三区| 日韩亚洲欧美高清| 亚洲高清不卡在线| 美女主播一区| 久久夜色精品国产欧美乱极品 |