真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

判斷一棵樹是否為完全二叉樹-創(chuàng)新互聯(lián)

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

10年積累的成都網(wǎng)站設計、網(wǎng)站制作經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先網(wǎng)站策劃后付款的網(wǎng)站建設流程,更有嵐縣免費網(wǎng)站建設讓你可以放心的選擇與我們合作。

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

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

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

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

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

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

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

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

bool _CheckCompleteTree(Node *root)
    {
        queue 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
#include
using namespace std;

template
struct BinaryTreeNode
{
    T _data;
    BinaryTreeNode *_left;
    BinaryTreeNode *_right;
    BinaryTreeNode(const T& d)
        :_data(d)
        , _left(NULL)
        , _right(NULL)
    {}
};

template
class BinaryTree
{
    typedef BinaryTreeNode 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 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 b1(a,10,'#');
    b1.CheckCompleteTree();
    int a2[9] = { 1, 2, '#', 3,'#', 4, '#', '#', 5 };
    BinaryTree b2(a2, 9, '#');
    b2.CheckCompleteTree();

    system("pause");
    return 0;
}

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

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

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

另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。


當前題目:判斷一棵樹是否為完全二叉樹-創(chuàng)新互聯(lián)
網(wǎng)頁地址:http://weahome.cn/article/esdss.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部