网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

c++中怎么构建一个先序二叉树-创新互联

本篇文章为大家展示了c++中怎么构建一个先序二叉树,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

湄潭网站制作公司哪家好,找创新互联建站!从网页设计、网站建设、微信开发、APP开发、成都响应式网站建设等网站项目制作,到程序开发,运营维护。创新互联建站从2013年成立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联建站

第一、定义BinaryTreeNode 类

#include 

#include 

#include 

using namespace std;

 

templateclass BinaryTree;

template  class BinaryTreeNode {

public:

  friend class BinaryTree;

  BinaryTreeNode() {

    data = NULL;

    lChild = rChild = NULL;

  }

  BinaryTreeNode(T newdata) {

    this->data = newdata;

    lChild = rChild = NULL;

  }

  T getData() {

    return data;

  }

  BinaryTreeNode * getLeftNode() {

    return lChild;

  }

  BinaryTreeNode * getRightNode() {

    return rChild;

  }

  T data;

  BinaryTreeNode* lChild;

  BinaryTreeNode* rChild;

private:

 

};

View Code

第二、定义BinaryTree 类

template  class BinaryTree {

public:

  BinaryTreeNode *root;

  char* p;

  BinaryTree() { root = NULL; }

  BinaryTree(T data) {

    root = new BinaryTreeNode(data);

    root->lChild = NULL;

    root->rChild = NULL;

  }

  ~BinaryTree() {

    delete root;

  }

 

  //构建二叉树并返回

  BinaryTreeNode* CreateTree() {

    BinaryTreeNode* bt = NULL;

    char t;

    cin >> t;

    if (t == '#')

    {

      return NULL;

    }

    else {

      int num = t - '0';

      bt = new BinaryTreeNode(num);

      bt->lChild = CreateTree();

      bt->rChild = CreateTree();

    }

    return bt;

  }

 

  //先序构建二叉树

  BinaryTreeNode* PreCreateTree() {

    BinaryTreeNode* bt = NULL;

    if (this->root == NULL)

    {

      cout << "请输入根节点(#代表空树):";

    }

    else {

      cout << "请输入节点(#代表空树):";

    }

    char t;

    cin >> t;

    if (t == '#')

    {

      return NULL;

    }

    else {

      int num = t - '0';

      bt = new BinaryTreeNode(num);

      if (this->root == NULL)

      {

        this->root = bt;

      }

      cout << bt->data << "的左孩子";

      bt->lChild = PreCreateTree();

 

      cout << bt->data << "的右边孩子";

      bt->rChild = PreCreateTree();

    }

    return bt;

  }  

 

  void preOderTraversal(BinaryTreeNode *bt); //先序遍历

  void inOrderTraversal(BinaryTreeNode *bt); //中序遍历

  void postOrderTraversal(BinaryTreeNode *bt);//后序遍历

  void levelTraversal(BinaryTreeNode *bt);  //逐层遍历

 

private:

 

};

 

template 

void BinaryTree::preOderTraversal(BinaryTreeNode *bt) {

  if (bt)

  {

    cout << bt->data;

    BinaryTree::preOderTraversal(bt->getLeftNode());

    BinaryTree::preOderTraversal(bt->getRightNode());

  }

}

 

template 

void BinaryTree::inOrderTraversal(BinaryTreeNode *bt) {

  if (bt)

  {

    BinaryTree::inOrderTraversal(bt->getLeftNode());

    cout << bt->data;

    BinaryTree::inOrderTraversal(bt->getRightNode());

  }

}

 

template 

void BinaryTree::postOrderTraversal(BinaryTreeNode *bt) {

  if (bt)

  {

    BinaryTree::postOrderTraversal(bt->getLeftNode());

    BinaryTree::postOrderTraversal(bt->getRightNode());

    cout << bt->data;

  }

}

 

template 

void BinaryTree::levelTraversal(BinaryTreeNode *bt) {

 

  queue*> que;

  que.push(bt);

  while (!que.empty())

  {

    BinaryTreeNode* proot = que.front();

    que.pop();

    cout << proot->data;

 

    if (proot->lChild != NULL)

    {

      que.push(proot->lChild);//左孩子入队

    }

    if (proot->rChild != NULL)

    {

      que.push(proot->rChild);//右孩子入队

    }

  }

}

View Code

第三、主程序运行

#include "pch.h"

#include 

#include "BinaryTree.h"

 

int main()

{

  //场景测试2

  BinaryTree btree;

  btree.PreCreateTree();//先序构建二叉树

  cout << "先序遍历:";

  btree.preOderTraversal(btree.root); cout << endl;//先序遍历  

  cout << "中序遍历:";

  btree.inOrderTraversal(btree.root); cout << endl;//中序遍历

  cout << "后序遍历:";

  btree.postOrderTraversal(btree.root); cout << endl;//后序遍历

  cout << "逐层序遍历:";

  btree.levelTraversal(btree.root);

 

}

View Code

最终测试运行截图

c++中怎么构建一个先序二叉树

上述内容就是c++中怎么构建一个先序二叉树,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联网站建设公司行业资讯频道。

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


标题名称:c++中怎么构建一个先序二叉树-创新互联
网站地址:http://bjjierui.cn/article/decssg.html

其他资讯