欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

判斷一棵樹是否為完全二叉樹

       完全二叉樹:若一棵二叉樹具有具有n個節(jié)點,它的每個節(jié)點都與高度為k的滿二叉樹編號為0~n-1結點一一對應,則稱這可二叉樹為完全二叉樹。

創(chuàng)新互聯(lián)是一家集網(wǎng)站建設,隆德企業(yè)網(wǎng)站建設,隆德品牌網(wǎng)站建設,網(wǎng)站定制,隆德網(wǎng)站建設報價,網(wǎng)絡營銷,網(wǎng)絡優(yōu)化,隆德網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強企業(yè)競爭力。可充分滿足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實用型網(wǎng)站。

方法一:一維數(shù)組存儲

 根據(jù)完全二叉樹的定義和性質,利用一位數(shù)組作為完全二叉樹的存儲,如下圖

判斷一棵樹是否為完全二叉樹

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

判斷一棵樹是否為完全二叉樹

但是該方法雖然實現(xiàn)容易,但占用空間太大,并且效率低,所以可通過層次遍歷來判斷是否為完全二叉樹。

方法二:層次遍歷(利用隊列)

      完全二叉樹是指最后一層左邊是滿的,右邊可能慢也不能不滿,然后其余層都是滿的,根據(jù)這個特性,利用層遍歷。如果我們當前遍歷到了NULL結點,如果后續(xù)還有非NULL結點,說明是非完全二叉樹。

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)站標題:判斷一棵樹是否為完全二叉樹
網(wǎng)站地址:http://aaarwkj.com/article20/ihhdjo.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設響應式網(wǎng)站、App開發(fā)網(wǎng)站策劃、商城網(wǎng)站、手機網(wǎng)站建設

廣告

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

網(wǎng)站建設網(wǎng)站維護公司
成年人免费在线观看毛片| 日韩亚洲欧洲一区二区三区| 亚洲视频一区视频二区| 国产一区精品在线免费看| 亚洲欧美日韩精品区| 国产成人综合久久三区北岛玲| 朝桐光日韩一区二区三区| 国产无人区码一区二区| 97在线观看视频在线观看| 亚洲婷婷久久一区二区| 日韩黄色资源在线观看| 国产免费成人午夜免费视频| 国产男女在线视频观看| 99久久久久国产精品免费 | av熟女乱一区二区三区| 精品成人在线一区二区| 日韩精品在线观看电影| 亚洲精品污一区二区三区| 亚洲精品a在线观看av| 国产毛片一区二区在线| 九九热99这里有精品| 精品人妻日韩中文字幕| 激情五月婷婷久久激情| 亚洲理论电影在线观看| 亚洲高清有码在线观看| 欧美乱与老熟妇视频观看| 无遮挡无掩盖的免费网站| 亚洲一区精品二人人爽久久| 69人妻一区二区三区蜜桃| 亚洲欧美日韩另类精品一区二区三区| 欧美精品蜜桃激情一区久久| 韩国午夜理伦三级好看| 亚洲三级黄色在线观看| 中文字幕欧美人妻在线| 侵犯人妻中文字幕一区二区| 97成品视频在线播放| 人人妻人人澡人人揉| 亚洲乱码精品一区二区| 午夜宅男在线视频观看| 色哟哟91精品色哟哟| 中国的性生活黄片免费观看|