zoukankan      html  css  js  c++  java
  • 毕业了C++二叉树层次遍历

    //代码经过测试,赋值粘贴即可用
    #include<iostream> #include<stdio.h> #include<stack> #include<queue> #include<malloc.h> using namespace std; //二叉树结点 typedef struct BTNode{ char data; struct BTNode *lchild; struct BTNode *rchild; }BTNode; //模板先序建立二叉树,大话p187,教科书吧版 BTNode *CreateBiTree()//只需要一个函数 { char ch; BTNode *T; scanf("%c",&ch); if(ch=='#') T=NULL; else { T = (BTNode *)malloc(sizeof(BTNode)); T->data = ch; T->lchild = CreateBiTree(); T->rchild = CreateBiTree(); } return T;//返回根节点 } //层次遍历 void LevelOrder(BTNode *T){ //queue<BTNode> queue;大bug隐藏在这个地方;注意queue这个容器装的是什么东西 queue<BTNode *> queue;
    queue.push(T); //算法:根结点入队列 while(!queue.empty()){ //若队列非空则循环执行下列的3个步骤 T = queue.front(); //步骤1:对头元素出队,指针从新指向,front()方法是将返回队头元素 printf("%c ",T->data);//队头元素出队然后将队头元素的左右孩子入队 queue.pop();//pop是出队 if(T->lchild != NULL){//步骤2:左子树不空,将左子树入队 queue.push(T->lchild);//入队的就是一个地址元素 } if(T->rchild != NULL){//步骤3:右子树不空,将右子树入队 queue.push(T->rchild); } } } int main() { BTNode *T; T = CreateBiTree();//建立 LevelOrder(T); return 0; }
  • 相关阅读:
    sap的几个报表工具
    调用CALL TRANSACTION的三种方法
    SDsap的SD, FI,MM的业务集成和SD业务常用到重要函数
    SAP标准OK Code Values 列表
    [转载]CHAR、VARCHAR、VARCHAR2与Number类型
    [转载]Oracle Minus关键字
    SQL MINUS
    [转载]Oracle Minus关键字
    Datastage教程
    [转载]ORA00001 违反唯一约束条件
  • 原文地址:https://www.cnblogs.com/cs-lcy/p/7071377.html
Copyright © 2011-2022 走看看