m0_68539462 2022-05-30 19:42 采纳率: 100%
浏览 20
已结题

二叉树创建后,遍历输出是?,怎么回事

二叉树已经创建好了,但是不管是先,中,后序遍历,输出都是一个 ?
怎么回事?
有哪位大能能帮我看看到底是哪错了?
下面是源代码和错误演示:


```c++
#include<stdio.h>
#include<stdlib.h>
void menu()
{
    printf("     二叉树\n");
    printf("1.建立二叉树\n");
    printf("2.先序遍历二叉树\n");
    printf("3.中序遍历二叉树\n");
    printf("4.后序遍历二叉树\n");
    printf("0.退出\n");
}
typedef struct BiTNode
{
    char data;
    struct BiTNode* lchild, * rchild;
}BiTNode, * BiTree;
void InitBiTree(BiTree& T)
{
    T = new BiTNode;
    T->lchild = T->rchild = NULL;
}
void CreateBiTree(BiTree T)
{
    char c;
    scanf_s("%c", &c);
    if (c == '#')
    {
        T = NULL;
    }
    else
    {
        T = new BiTNode;
        T->data = c;
        CreateBiTree(T->lchild);
        CreateBiTree(T->rchild);
    }
}
void PreOrder(BiTree T)
{
    if (T != NULL)
    {
        printf("%c ", T->data);
        PreOrder(T->lchild);
        PreOrder(T->rchild);
    }
}
void InOrder(BiTree T)
{
    if (T != NULL)
    {
        InOrder(T->lchild);
        printf("%c ", T->data);
        InOrder(T->rchild);
    }
}
void PostOrder(BiTree T)
{
    if (T != NULL)
    {
        PostOrder(T->lchild);
        PostOrder(T->rchild);
        printf("%c ", T->data);
    }
}
int main()
{
    int choice;
    BiTree T;
    InitBiTree(T);
    menu();
    while (1)
    {
        printf("要进行的操作:\n");
        scanf_s("%d", &choice);
        switch (choice)
        {
        case 1:
            printf("请输入二叉树节点元素(无元素用#代替):\n");
            CreateBiTree(T);
            printf("创建成功!\n");
            break;
        case 2:
            PreOrder(T);
            break;
        case 3:
            InOrder(T);
            break;
        case 4:
            PostOrder(T);
            break;
        default:
            printf("你的输入有误,请重新输入:\n");
        }
    }
    return 0;
}



![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/050449019356158.png "#left")
  • 写回答

1条回答 默认 最新

  • 赵4老师 2022-05-31 11:14
    关注

    仅供参考:

    #include <iostream>
    #include <stack>
    #include <queue>
    #include <locale.h>
    using namespace std;
    typedef struct BiTNode {//二叉树结点
        char data;                      //数据
        struct BiTNode *lchild,*rchild; //左右孩子指针
    } BiTNode,*BiTree;
    int CreateBiTree(BiTree &T) {//按先序序列创建二叉树
        char data;
        scanf("%c",&data);//按先序次序输入二叉树中结点的值(一个字符),‘#’表示空树
        if (data == '#') {
            T = NULL;
        } else {
            T = (BiTree)malloc(sizeof(BiTNode));
            T->data = data;         //生成根结点
            CreateBiTree(T->lchild);//构造左子树
            CreateBiTree(T->rchild);//构造右子树
        }
        return 0;
    }
    void Visit(BiTree T) {//输出
        if (T->data != '#') {
            printf("%c ",T->data);
        }
    }
    void PreOrder(BiTree T) {//先序遍历
        if (T != NULL) {
            Visit(T);               //访问根节点
            PreOrder(T->lchild);    //访问左子结点
            PreOrder(T->rchild);    //访问右子结点
        }
    }
    void InOrder(BiTree T) {//中序遍历
        if (T != NULL) {
            InOrder(T->lchild);     //访问左子结点
            Visit(T);               //访问根节点
            InOrder(T->rchild);     //访问右子结点
        }
    }
    void PostOrder(BiTree T) {//后序遍历
        if (T != NULL) {
            PostOrder(T->lchild);   //访问左子结点
            PostOrder(T->rchild);   //访问右子结点
            Visit(T);               //访问根节点
        }
    }
    void PreOrder2(BiTree T) {//先序遍历(非递归)
    //访问T->data后,将T入栈,遍历左子树;遍历完左子树返回时,栈顶元素应为T,出栈,再先序遍历T的右子树。
        stack<BiTree> stack;
        BiTree p = T;//p是遍历指针
        while (p || !stack.empty()) {   //栈不空或者p不空时循环
            if (p != NULL) {
                stack.push(p);          //存入栈中
                printf("%c ",p->data);  //访问根节点
                p = p->lchild;          //遍历左子树
            } else {
                p = stack.top();        //退栈
                stack.pop();
                p = p->rchild;          //访问右子树
            }
        }
    }
    void InOrder2(BiTree T) {//中序遍历(非递归)
    //T是要遍历树的根指针,中序遍历要求在遍历完左子树后,访问根,再遍历右子树。
    //先将T入栈,遍历左子树;遍历完左子树返回时,栈顶元素应为T,出栈,访问T->data,再中序遍历T的右子树。
        stack<BiTree> stack;
        BiTree p = T;//p是遍历指针
        while (p || !stack.empty()) {   //栈不空或者p不空时循环
            if (p != NULL) {
                stack.push(p);          //存入栈中
                p = p->lchild;          //遍历左子树
            } else {
                p = stack.top();        //退栈,访问根节点
                printf("%c ",p->data);
                stack.pop();
                p = p->rchild;          //访问右子树
            }
        }
    }
    
    typedef struct BiTNodePost{
        BiTree biTree;
        char tag;
    } BiTNodePost,*BiTreePost;
    void PostOrder2(BiTree T) {//后序遍历(非递归)
        stack<BiTreePost> stack;
        BiTree p = T;//p是遍历指针
        BiTreePost BT;
        while (p != NULL || !stack.empty()) {//栈不空或者p不空时循环
            while (p != NULL) {//遍历左子树
                BT = (BiTreePost)malloc(sizeof(BiTNodePost));
                BT->biTree = p;
                BT->tag = 'L';//访问过左子树
                stack.push(BT);
                p = p->lchild;
            }
            while (!stack.empty() && (stack.top())->tag == 'R') {//左右子树访问完毕访问根节点
                BT = stack.top();
                stack.pop();//退栈
                printf("%c ",BT->biTree->data);
            }
            if (!stack.empty()) {//遍历右子树
                BT = stack.top();
                BT->tag = 'R';//访问过右子树
                p = BT->biTree;
                p = p->rchild;
            }
        }
    }
    
    void LevelOrder(BiTree T) {//层次遍历
        if (T == NULL) return;
        BiTree p = T;
        queue<BiTree> queue;//队列
        queue.push(p);//根节点入队
        while (!queue.empty()) {    //队列不空循环
            p = queue.front();      //对头元素出队
            printf("%c ",p->data);  //访问p指向的结点
            queue.pop();            //退出队列
            if (p->lchild != NULL) {//左子树不空,将左子树入队
                queue.push(p->lchild);
            }
            if (p->rchild != NULL) {//右子树不空,将右子树入队
                queue.push(p->rchild);
            }
        }
    }
    int main() {
        BiTree T;
    
        setlocale(LC_ALL,"chs");
        CreateBiTree(T);
    
        printf("先序遍历        :");PreOrder  (T);printf("\n");
        printf("先序遍历(非递归):");PreOrder2 (T);printf("\n");
                                                   printf("\n");
        printf("中序遍历        :");InOrder   (T);printf("\n");
        printf("中序遍历(非递归):");InOrder2  (T);printf("\n");
                                                   printf("\n");
        printf("后序遍历        :");PostOrder (T);printf("\n");
        printf("后序遍历(非递归):");PostOrder2(T);printf("\n");
                                                   printf("\n");
        printf("层次遍历        :");LevelOrder(T);printf("\n");
    
        return 0;
    }
    //ABC##DE#G##F###
    //先序遍历        :A B C D E G F
    //先序遍历(非递归):A B C D E G F
    //
    //中序遍历        :C B E G D F A
    //中序遍历(非递归):C B E G D F A
    //
    //后序遍历        :C G E F D B A
    //后序遍历(非递归):C G E F D B A
    //
    //层次遍历        :A B C D E F G
    //
    
    ///       A
    ///      /
    ///     B
    ///    / \
    ///   C   D
    ///      / \
    ///     E   F
    ///      \
    ///       G
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 6月14日
  • 已采纳回答 6月6日
  • 创建了问题 5月30日

悬赏问题

  • ¥15 乌班图ip地址配置及远程SSH
  • ¥15 怎么让点阵屏显示静态爱心,用keiluVision5写出让点阵屏显示静态爱心的代码,越快越好
  • ¥15 PSPICE制作一个加法器
  • ¥15 javaweb项目无法正常跳转
  • ¥15 VMBox虚拟机无法访问
  • ¥15 skd显示找不到头文件
  • ¥15 机器视觉中图片中长度与真实长度的关系
  • ¥15 fastreport table 怎么只让每页的最下面和最顶部有横线
  • ¥15 java 的protected权限 ,问题在注释里
  • ¥15 这个是哪里有问题啊?