亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

二叉樹的遍歷算法(詳細示例分析)

2020-01-24 03:22:34
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

#include<iostream>
#include<assert.h>
#include<stack>
#include<queue>
using namespace std;
struct Node
{
    int v;
    Node *leftChild,*rightChild;
    Node():leftChild(NULL),rightChild(NULL){}
    Node(int vv):leftChild(NULL),rightChild(NULL)
    {
        v=vv;
    }
};

void print(int v)
{
    cout<<v<<"   ";
}
void PreOrderTraverse(Node *n, void (* visit)(int))
{
    assert(n!=NULL&&visit!=NULL);
    (*visit)(n->v);
    if(n->leftChild!=NULL) PreOrderTraverse(n->leftChild,visit);
    if(n->rightChild!=NULL) PreOrderTraverse(n->rightChild,visit);
}

void InOrderTraverse(Node *n, void (* visit)(int))
{
    assert(n!=NULL&&visit!=NULL);
    if(n->leftChild!=NULL) InOrderTraverse(n->leftChild,visit);
    (*visit)(n->v);
    if(n->rightChild!=NULL) InOrderTraverse(n->rightChild,visit);
}

void PostOrderTraverse(Node *n, void (* visit)(int))
{
    assert(n!=NULL&&visit!=NULL);
    if(n->leftChild!=NULL) PostOrderTraverse(n->leftChild,visit);
    if(n->rightChild!=NULL) PostOrderTraverse(n->rightChild,visit);
    (*visit)(n->v);
}
//非遞歸版本,將遞歸改成非遞歸一般都要利用一個棧
//每次訪問一個結點后,在向左子樹遍歷下去之前,利用這個棧記錄該結點的右子女(如果有的話)結點的地址,
//以便在左子樹退回時可以直接從棧頂取得右子樹的根結點,繼續右子樹的遍歷
void PreOrder(Node *n, void (* visit)(int))
{
    stack<Node*> sta;
    sta.push(n);
    while(!sta.empty())
    {
        Node * t=sta.top();
        sta.pop();
        assert(t!=NULL);
        (*visit)(t->v);
        if(t->rightChild!=NULL) sta.push(t->rightChild);
        if(t->leftChild!=NULL) sta.push(t->leftChild);
    }
}

//非遞歸中序遍歷
void InOrder(Node * n , void (* visit) (int))
{
    stack<Node *> sta;
    sta.push(n);
    Node * p= n;
    while(!sta.empty()&&p!=NULL)
    {
        p=sta.top();
        while(p!=NULL&&!sta.empty())
        {
            sta.push(p->leftChild);
            p=p->leftChild;
        }
        sta.pop();//彈出空指針
        if(!sta.empty())
        {
            p=sta.top();
            sta.pop();
            (*visit)(p->v);
            sta.push(p->rightChild);
        }
    }
}


//非遞歸后續遍歷

struct StkNode
{
    Node * ptr;
    bool tag;//false=left and true=right
    StkNode():ptr(NULL),tag(false)
    {}
};
void PostOrder(Node * n ,void (*visit) (int))
{
    stack<StkNode> sta;
    StkNode w;
    Node * p = n;
    do {
        while(p!=NULL)
        {
            w.ptr=p;
            w.tag=false;
            sta.push(w);
            p=p->leftChild;
        }
        bool flag=true;
        while(flag&&!sta.empty())
        {
            w=sta.top();
            sta.pop();
            p=w.ptr;
            if(!w.tag)//left,如果從左子樹返回,則開始遍歷右子樹
            {
                w.tag=true;//標記右子樹
                sta.push(w);
                flag=false;
                p=p->rightChild;
            }
            else
            {
                (*visit)(p->v);
            }
        }
    } while(!sta.empty());
}

//層序遍歷,利用隊列
void LevelOrderTraverse(Node * n , void (* visit )(int))
{
    assert(n!=NULL&&visit!=NULL);
    queue<Node * > que;
    que.push(n);
    while(!que.empty())
    {
        Node * t=que.front();
        (*visit)(t->v);
        que.pop();
        if(t->leftChild!=NULL) que.push(t->leftChild);
        if(t->rightChild!=NULL) que.push(t->rightChild);
    }
}

int main()
{
    Node * head= new Node(0);
    Node * node1= new Node(1);
    Node * node2= new Node(2);
    Node * node3= new Node(3);
    Node * node4= new Node(4);
    Node * node5= new Node(5);
    Node * node6= new Node(6);


    head->leftChild=node1;
    head->rightChild=node2;   
    node1->leftChild=node3;
    node1->rightChild=node4;
    node2->rightChild=node5;
    node4->leftChild=node6;

   
/*    LevelOrderTraverse(head,print);
    cout<<endl;
    PreOrderTraverse(head,print);
    cout<<endl;*/
    InOrder(head,print);
    cout<<endl;
    InOrderTraverse(head,print);
    cout<<endl;

    PostOrder(head,print);
    cout<<endl;
    PostOrderTraverse(head,print);
    cout<<endl;
    return 0;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国模精品系列视频| 欧美成人免费播放| 国内精品美女av在线播放| 国产精品成人一区二区| 国产成人自拍视频在线观看| 最近2019中文免费高清视频观看www99| 日韩av成人在线| 久久久久久久亚洲精品| 精品国产一区av| 国产suv精品一区二区三区88区| 亚洲免费福利视频| 久久久免费精品视频| 国产成+人+综合+亚洲欧美丁香花| 亚洲另类图片色| 91精品国产成人| 亚洲国产精品一区二区三区| 日韩av免费看网站| 亚洲精品国产精品自产a区红杏吧| 91av福利视频| 精品国产一区二区三区四区在线观看| 欧美一区二区三区免费观看| 日韩在线观看网站| 久久99热这里只有精品国产| 欧美精品一区在线播放| 国产精品黄色影片导航在线观看| 国产成人在线播放| 91免费看片在线| 中文字幕亚洲综合久久| 日韩成人激情在线| 亚洲国产福利在线| 夜夜嗨av色一区二区不卡| 国产日韩专区在线| 国产美女91呻吟求| 欧美日韩国产二区| 91丝袜美腿美女视频网站| 97视频在线观看播放| 亚洲国模精品私拍| 国产精品91在线观看| 国产精品夜间视频香蕉| 日本三级韩国三级久久| 色噜噜久久综合伊人一本| 日本亚洲欧洲色α| 欧美精品在线免费播放| 亚洲国产91精品在线观看| 欧美一级淫片aaaaaaa视频| 亚洲a一级视频| 精品日本美女福利在线观看| 一区二区三区视频在线| 欧美在线视频一区二区| 国产精品老牛影院在线观看| 亚洲国产精品久久| 亚洲免费人成在线视频观看| 亚洲欧美日本伦理| 亚洲色图欧美制服丝袜另类第一页| 欧美日韩中文字幕日韩欧美| 国产精品久久久久av免费| 中文字幕在线精品| 欧美诱惑福利视频| 久久久久中文字幕2018| 精品国产欧美成人夜夜嗨| 欧美日韩日本国产| 国内外成人免费激情在线视频| 精品毛片网大全| 久久久久成人精品| 欧美午夜宅男影院在线观看| 午夜精品久久久久久久99热浪潮| 亚洲自拍欧美另类| 欧美大全免费观看电视剧大泉洋| 爽爽爽爽爽爽爽成人免费观看| 日本91av在线播放| 国产精品影片在线观看| 亚洲xxxxx电影| 自拍偷拍亚洲区| 亚洲免费av电影| 欧美精品一区二区三区国产精品| 久久青草福利网站| 九九九热精品免费视频观看网站| 国产日韩中文字幕在线| 91精品久久久久久久久久| 国产精品2018| 97在线免费观看| 97免费中文视频在线观看| 国产一区私人高清影院| 国产成+人+综合+亚洲欧美丁香花| 91色精品视频在线| 国产成人精品一区二区在线| 疯狂做受xxxx高潮欧美日本| 欧美日韩成人网| 在线免费看av不卡| 国产精品美女久久| 国产精品免费看久久久香蕉| 久久精品一本久久99精品| 韩国三级日本三级少妇99| 91av在线不卡| 亚洲自拍偷拍色片视频| 亚洲国产精品美女| 欧美贵妇videos办公室| 亚洲成人中文字幕| 性色av一区二区三区| 亚洲欧美日韩国产中文专区| 亚州av一区二区| 久久久成人av| 国产精品9999| 欧美福利小视频| 午夜精品国产精品大乳美女| 91精品啪aⅴ在线观看国产| 久久久久久久一区二区| 亚洲精品aⅴ中文字幕乱码| 97精品视频在线播放| 欧美一级淫片丝袜脚交| 成人精品在线视频| 美日韩精品视频免费看| 中文字幕亚洲欧美日韩2019| 欧美体内谢she精2性欧美| 中文字幕精品www乱入免费视频| 色777狠狠综合秋免鲁丝| 超碰97人人做人人爱少妇| 欧美激情一级精品国产| 欧美高清无遮挡| 亚洲欧洲激情在线| 日本久久久久久| 91网站免费看| 91在线视频成人| 日韩精品在线免费播放| 亚洲国产精品成人va在线观看| 日本国产高清不卡| 亚洲综合第一页| 国语自产精品视频在线看一大j8| 国色天香2019中文字幕在线观看| 久久免费少妇高潮久久精品99| 日韩成人小视频| 久久久久国产精品www| 久久久久久香蕉网| 久久99热精品这里久久精品| 伊人久久久久久久久久久| 国产视频精品va久久久久久| 精品人伦一区二区三区蜜桃网站| 欧美巨大黑人极品精男| 中文字幕一精品亚洲无线一区| 欧美性xxxx极品hd欧美风情| 色综合色综合久久综合频道88| 久久久精品久久久| 日韩欧美亚洲综合| 欧美高清自拍一区| 成人深夜直播免费观看| 亚洲自拍av在线| 久久久成人av| 亚洲性生活视频| 欧美在线播放视频| 57pao成人国产永久免费| 亚洲免费电影一区| 韩日精品中文字幕| 国产日韩精品综合网站| 一区二区成人精品| 91香蕉嫩草神马影院在线观看| 欧美老妇交乱视频| 欧美一区二区三区精品电影| 中文字幕日韩专区| 国产主播喷水一区二区| 久久久之久亚州精品露出| 欧美日韩中文字幕综合视频| 国产精品丝袜白浆摸在线| 国产精品久久久久久久av电影| 98午夜经典影视|