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

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

二叉樹前序、中序和后序的非遞歸遍歷

非遞歸遍歷二叉樹利用棧的先進先出特點完成實現(xiàn)

創(chuàng)新互聯(lián)客戶idc服務(wù)中心,提供聯(lián)通服務(wù)器托管、成都服務(wù)器、成都主機托管、成都雙線服務(wù)器等業(yè)務(wù)的一站式服務(wù)。通過各地的服務(wù)中心,我們向成都用戶提供優(yōu)質(zhì)廉價的產(chǎn)品以及開放、透明、穩(wěn)定、高性價比的服務(wù),資深網(wǎng)絡(luò)工程師在機房提供7*24小時標準級技術(shù)保障。

前序比較好理解先壓根入棧,在while里面訪問根,根出棧,再壓入右子樹,左子樹,這樣的遍歷二叉樹就是前序遍歷了。

void PrevOrdr_NonR()

{

    stack*> s;

    s.push(_root);

    while(!s.empty())

    {

       BinaryTreeNode* top = s.top();

       s.pop();

       cout<_data<<" ";

       if(top->_right)

           s.push(top->_right);

       if(top->_left)

           s.push(top->_left); 

    }

    cout<

}

中序的遍歷順序是左子樹、根節(jié)點、右子樹。

void InOreder_NonR()

{

    stack*> s;

    BinaryTreeNode* cur = _root;

    while(cur || !s.empty())

    {

        while(cur)//把左路徑的節(jié)點全部壓入棧

        {

            s.push(cur);

            cur = cur->_left;

        }

        if(!s.empty())

        {

            BinaryTreeNode* top = s.top();

            s.pop();

            cout<_data<<" ";

            cur = cur->_right;//把cur指向最后一個左節(jié)點的右節(jié)點

        }

    }

    cout<

}

后序遍歷是左子樹、右子樹、根節(jié)點。

void PostOrder_NonR()

{

    stack*> s;

    BinaryTreeNode* cur = _root;

    BinaryTreeNode* prevVisited = NULL;

    while(cur || s.empty())

    {

        while(cur)//左路徑的節(jié)點入棧

        {

            s.push(cur);

            cur = cur->_left;

        }

        BinaryTreeNode* top = s.top();

        if(top->_right == NULL || top->right == preVisited)

        //當子樹遍歷之后回退到上一個沒有遍歷的子樹

        {

            cout<_data<<" ";

            preVisited = tmp;

            s.pop();

        }

        else

        {

            cur = cur->left;//把cur指向右子樹繼續(xù)尋找左節(jié)點

        }

    }

}


分享題目:二叉樹前序、中序和后序的非遞歸遍歷
本文鏈接:http://weahome.cn/article/gescpo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部