91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

數據結構C++使用最小堆實現huffman樹

發布時間:2020-04-06 14:26:48 來源:網絡 閱讀:498 作者:zheng_feng 欄目:編程語言

#pragma once

#include"Heap.h"http://使用博客實現的堆

template<class T>

struct HuffmanNode//節點的結構信息

{

T _weight;

HuffmanNode<T>* _parent;

HuffmanNode<T>* _left;

HuffmanNode<T>* _right;

HuffmanNode(const T& weight)

:_weight(weight)

, _parent(NULL)

, _left(NULL)

, _right(NULL)

{}

};

template<class T>

class HuffmanTree//huffman樹的實現

{

typedef HuffmanNode<T> Node;

public:

HuffmanTree()

:_root(NULL)

{}

~HuffmanTree()

{

_Destroy(_root);

_root = NULL;

}

Node* GetRootNode()

{

return _root;

}

void CreateHuffmanTree(const T* array, size_t size, const T& invalid)

{

assert(array && size > 0);

struct Compare

{

bool operator()(Node*& l, Node*& r)

{

return (l->_weight < r->_weight);

}

};

////Heap<Node*,Compare> minHeap(array, size);

Heap<Node*, Compare> minHeap;

for (size_t i = 0; i < size; ++i)

{

if (array[i] != invalid)

{

Node* node = new Node(array[i]);

minHeap.Push(node);

}


}

if (minHeap.Empty())

return;

Node* parent = minHeap.GetTop();

while (minHeap.Size() > 1)

{

Node* first = minHeap.GetTop();

minHeap.Pop();

Node* second = minHeap.GetTop();

minHeap.Pop();

parent = new Node(first->_weight+second->_weight);

parent->_left = first;

parent->_right = second;

minHeap.Push(parent);

}

_root = parent;

}

void LevelOrder()

{

queue<Node*> q;

if (_root == NULL)

return;

q.push(_root);

while (!q.empty())

{

Node* cur = q.front();

q.pop();

cout << cur->_weight << " ";

if (cur->_left)

q.push(cur->_left);

if (cur->_right)

q.push(cur->_right);

}

}

private:

void _Destroy(Node*& root)

{

if (root == NULL)

return;

_Destroy(root->_left);

_Destroy(root->_right);

delete root;

root = NULL;

}


protected:

Node* _root;

};

void TestTree()

{

int ar[] = { 2, 3, 6, 0, 4, 5, 1, 9, 7, 8 };

//int ar[] = { 1,1,1,1,2,2 };

HuffmanTree<int> tree;

tree.CreateHuffmanTree(ar, sizeof(ar) / sizeof(ar[0]), -1);

tree.LevelOrder();

}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

华容县| 教育| 苗栗市| 定陶县| 拜城县| 卢龙县| 高阳县| 龙江县| 汉寿县| 辽阳县| 特克斯县| 防城港市| 茶陵县| 佛教| 开平市| 淮北市| 图们市| 宜城市| 博湖县| 革吉县| 浮梁县| 康定县| 鄂托克前旗| 澄城县| 大冶市| 武鸣县| 贵南县| 新巴尔虎左旗| 宁远县| 宁强县| 红原县| 莫力| 吉木萨尔县| 平和县| 东至县| 佛学| 乐都县| 韶关市| 土默特右旗| 石景山区| 通道|