您好,登錄后才能下訂單哦!
完全二叉樹:若一棵二叉樹具有具有n個節(jié)點,它的每個節(jié)點都與高度為k的滿二叉樹編號為0~n-1結(jié)點一一對應(yīng),則稱這可二叉樹為完全二叉樹。
方法一:一維數(shù)組存儲
根據(jù)完全二叉樹的定義和性質(zhì),利用一位數(shù)組作為完全二叉樹的存儲,如下圖
由圖,節(jié)點的編號與數(shù)組元素的下標(biāo)是一一對應(yīng)的,可根據(jù)二叉樹的性質(zhì),可方便找出下標(biāo) 為i的的雙親結(jié)點a[i/2]及左右孩子結(jié)點a[i*2],a[i*2+1].這樣判斷一棵樹是否為二叉樹,應(yīng)該對此二叉樹從上到下,從左到右依次編號, 然后把編好的號依次存入一位數(shù)組中,在與相應(yīng)深度的滿二叉樹的編號進行對比,即可判斷此二叉樹是否為完全二叉樹。
但是該方法雖然實現(xiàn)容易,但占用空間太大,并且效率低,所以可通過層次遍歷來判斷是否為完全二叉樹。
方法二:層次遍歷(利用隊列)
完全二叉樹是指最后一層左邊是滿的,右邊可能慢也不能不滿,然后其余層都是滿的,根據(jù)這個特性,利用層遍歷。如果我們當(dāng)前遍歷到了NULL結(jié)點,如果后續(xù)還有非NULL結(jié)點,說明是非完全二叉樹。
bool _CheckCompleteTree(Node *root) { queue<Node*> q; if (root == NULL) //空樹是完全二叉樹 return true; q.push(root); bool flag = false; while (!q.empty()) { Node* front = q.front(); if (front != NULL) { if (flag) return false; q.push(front->_left); q.push(front->_right); } else flag = true; q.pop(); } return true; }
完整代碼及測試用例
#include<iostream> #include<queue> using namespace std; template<class T> struct BinaryTreeNode { T _data; BinaryTreeNode *_left; BinaryTreeNode *_right; BinaryTreeNode(const T& d) :_data(d) , _left(NULL) , _right(NULL) {} }; template<class T> class BinaryTree { typedef BinaryTreeNode<T> Node; public: BinaryTree() :_root(NULL) {} BinaryTree(const T *a, size_t size, const T& invalid) { size_t index = 0; _root = _CreateNode(a, size, index, invalid); } void CheckCompleteTree() { bool ret; ret = _CheckCompleteTree(_root); cout << "Is a complate BinaryTree?:" << ret << endl; } protected: bool _CheckCompleteTree(Node *root) { queue<Node*> q; if (root == NULL) //空樹是完全二叉樹 return true; q.push(root); bool flag = false; while (!q.empty()) { Node* front = q.front(); if (front != NULL) { if (flag) return false; q.push(front->_left); q.push(front->_right); } else flag = true; q.pop(); } return true; } Node * _CreateNode(const T* a, size_t size, size_t& index, const T& invalid) { Node* root = NULL; while ((index < size) && (a[index] != invalid)) { root = new Node(a[index]); root->_left = _CreateNode(a, size, ++index, invalid); root->_right = _CreateNode(a, size, ++index, invalid); } return root; } protected: Node* _root; }; int main() { int a[10] = { 1, 2, 3, '#', '#', 4, '#', '#', 5, 6, }; BinaryTree<int> b1(a,10,'#'); b1.CheckCompleteTree(); int a2[9] = { 1, 2, '#', 3,'#', 4, '#', '#', 5 }; BinaryTree<int> b2(a2, 9, '#'); b2.CheckCompleteTree(); system("pause"); return 0; }
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。