zoukankan      html  css  js  c++  java
  • 二叉树的遍历

    二叉树的遍历

    给定一个二叉树,返回它的遍历。

    节点的信息:

    // 结构体
    struct TreeNode
    {
        TreeNode*left;
        TreeNode*right;
        char data;
    };
    typedef  TreeNode* BTree;

    前序访问的递归写法

    void PreOrder(TreeNode*root){
        if (root==NULL)
        {
            return;            //若结点为空
        }
        cout<<root->data;         //输出根节点的值
        PreOrder(root->left);     //前序访问左子树
        PreOrder(root->right);    //前序访问右子树
    }

    前序访问的非递归写法

    void PreOrderLoop(TreeNode*root){
        stack<TreeNode*>s;
        TreeNode*cur,*top;
        cur = root;
        while(cur!=NULL||!s.empty()){
            while (cur!=NULL)
            {
                cout<<cur->data;
                s.push(cur);
                cur=cur->left;
            }
            top=s.top();
            s.pop();
            cur =top->right;
        }
    }

    中序遍历的递归写法

    void InOrder(TreeNode*root){
        if(root==NULL){
            return;            //若结点为空
        }
        InOrder(root->left); //中序遍历左子树
        cout<<root->data; //访问节点值
        InOrder(root->right);  //中序遍历右子树
    }

    中序访问的非递归写法

    void InOrderLoop(TreeNode *root){
        stack<TreeNode *>s;
        TreeNode *cur;
        cur=root;
        while (cur!=NULL||!s.empty()){
            while(cur!=NULL){
                s.push(cur);
                cur=cur->left;
            }
            cur = s.top();
            s.pop();
            cout<<cur->data;
            cur=cur->right;
        }
    }

    后序遍历的递归写法

    void PostOrder(TreeNode*root){
        if(root==NULL){
            return;            //若结点为空
        }
        InOrder(root->left); //后序遍历左子树
        InOrder(root->right);  //后序遍历右子树
        cout<<root->data; //访问节点值
    }

    后序访问的非递归写法

    void PostOrderLoop(TreeNode *root){
        stack<TreeNode *>s;
        TreeNode *cur,*top,*last=NULL;
        cur=root;
        while (cur!=NULL||!s.empty()){
            while(cur!=NULL){
                s.push(cur);
                cur=cur->left;
            }
            top = s.top();
            if(top->right==NULL||top->right==last){
                s.pop();
                cout<<top->data;
                last=top;
            }else{
                cur =top->right;
            }
        }
    }

    层序遍历

    void LevelOrder(TreeNode* root){
        queue<TreeNode*>q;
        TreeNode *front;
        if(root==NULL)return;
        q.push(root);
        while (!q.empty())
        {
            front = q.front();
            q.pop();
            if (front->left)
            {
                q.push(front->left);
            }
            if (front->right)
            {
                q.push(front->right);
            }
            cout<<front->data;
            
        }
    }

    建树

    BTree  CreateBTree()
    {
        BTree bt = NULL;
        char ch;
        cin>>ch;
        if (ch != '#')
        {
            bt = new TreeNode;
            bt->data = ch;
            bt->left = CreateBTree();
            bt->right = CreateBTree();
        }
        return bt;
    }

    统计叶子结点的数目,方法一

    int leftCount=0;
    void leaf1(BTree root){
        if(root!=NULL){
            leaf1(root->left);
            leaf1(root->right);
            if(root->left==NULL&&root->right==NULL){
                leftCount++;
            }
        }
    }

    统计叶子结点的数目,方法二

    int leaf2(BTree root){
        int leftC=0;
        if(root==NULL)leftCount=0;
        else if (root->left==NULL&&root->right==NULL)
        {
            leftC=1;
        }else
        {
            leftC=leaf2(root->left)+leaf2(root->right);
        }
        return leftC;
    }

    求二叉树的高度

    int TreeDepth(BTree bt)
    {
        int hl,hr,max;
        if(bt!=NULL)
        {
            hl=TreeDepth(bt->left);
            hr=TreeDepth(bt->right);
            max=hl>hr?hl:hr;
            return(max+1);
        }
        else return(0);
    }

     

    因上求缘,果上努力~~~~ 作者:每天卷学习,转载请注明原文链接:https://www.cnblogs.com/BlairGrowing/p/12765640.html

  • 相关阅读:
    ASP.Net 反射显示
    ASP.Net 反射简单工厂模式
    ASP.Net MVC生成验证码
    ASP.Net EF架构
    ASP.Net 邮箱发送
    ASP.Net 反射简单
    ASP.Net 显示
    新年快乐
    测试开发比
    Linkbot介绍
  • 原文地址:https://www.cnblogs.com/BlairGrowing/p/12765640.html
Copyright © 2011-2022 走看看