完全二叉樹:若一棵二叉樹具有具有n個(gè)節(jié)點(diǎn),它的每個(gè)節(jié)點(diǎn)都與高度為k的滿二叉樹編號為0~n-1結(jié)點(diǎn)一一對應(yīng),則稱這可二叉樹為完全二叉樹。
創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),隆德企業(yè)網(wǎng)站建設(shè),隆德品牌網(wǎng)站建設(shè),網(wǎng)站定制,隆德網(wǎng)站建設(shè)報(bào)價(jià),網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,隆德網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時(shí)我們時(shí)刻保持專業(yè)、時(shí)尚、前沿,時(shí)刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
方法一:一維數(shù)組存儲(chǔ)
根據(jù)完全二叉樹的定義和性質(zhì),利用一位數(shù)組作為完全二叉樹的存儲(chǔ),如下圖

由圖,節(jié)點(diǎn)的編號與數(shù)組元素的下標(biāo)是一一對應(yīng)的,可根據(jù)二叉樹的性質(zhì),可方便找出下標(biāo) 為i的的雙親結(jié)點(diǎn)a[i/2]及左右孩子結(jié)點(diǎn)a[i*2],a[i*2+1].這樣判斷一棵樹是否為二叉樹,應(yīng)該對此二叉樹從上到下,從左到右依次編號, 然后把編好的號依次存入一位數(shù)組中,在與相應(yīng)深度的滿二叉樹的編號進(jìn)行對比,即可判斷此二叉樹是否為完全二叉樹。

但是該方法雖然實(shí)現(xiàn)容易,但占用空間太大,并且效率低,所以可通過層次遍歷來判斷是否為完全二叉樹。
方法二:層次遍歷(利用隊(duì)列)
完全二叉樹是指最后一層左邊是滿的,右邊可能慢也不能不滿,然后其余層都是滿的,根據(jù)這個(gè)特性,利用層遍歷。如果我們當(dāng)前遍歷到了NULL結(jié)點(diǎn),如果后續(xù)還有非NULL結(jié)點(diǎn),說明是非完全二叉樹。
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;
}

網(wǎng)站標(biāo)題:判斷一棵樹是否為完全二叉樹
網(wǎng)站地址:http://chinadenli.net/article20/ihhdjo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、響應(yīng)式網(wǎng)站、App開發(fā)、網(wǎng)站策劃、商城網(wǎng)站、手機(jī)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)