【问题标题】:Create and traverse a binary tree recursively in C在 C 中递归地创建和遍历二叉树
【发布时间】:2013-05-19 13:08:33
【问题描述】:

我想创建一个二叉树并通过前序遍历来遍历它,并且我使用递归方法。这些代码可以编译但不能正常运行,我发现可能无法完成CreateBitree()函数,但不知道问题出在哪里。

#include <stdio.h>
#include <malloc.h>

typedef struct BiNode{
    int data;
    struct BiNode *lchild;
    struct BiNode *rchild;    //left and right child pointer
}BiNode;

int CreateBiTree(BiNode *T);
int TraverseBiTree(BiNode *T);

int main() {
    BiNode *t;
    CreateBiTree(t);
    TraverseBiTree(t);
    return 0;
}

int CreateBiTree(BiNode *T) {          //create a binary tree by preorder traversal
    char tmp;
    scanf("%c", &tmp);
    if(tmp == ' ')
    T = NULL;
    else {
        T = (BiNode *)malloc(sizeof(BiNode));
        T -> data = tmp;
        CreateBiTree(T -> lchild);
        CreateBiTree(T -> rchild);
    }
    return 1;
}

int TraverseBiTree(BiNode *T) {        //traverse a binary tree by preorder traversal
    if(T != NULL) {
        printf("%c\n", T -> data);
        TraverseBiTree(T -> lchild);
        TraverseBiTree(T -> rchild);
    }
    return 1;
}

例如,当我输入“ABC##DE#G##F###”(“#”表示空格)之类的预购序列,然后它仍然让我输入时,我认为TraverseBiTree()函数没有'没有被处决。

【问题讨论】:

  • 当你说它不起作用时......你的意思是什么?放错了吗?分段故障?还有什么?
  • 您通过 value 将指针值传递给 CreateBiTree。调用方永远不会得到更新的指针(包括它自己)。

标签: c recursion


【解决方案1】:

将指针值分配给函数内的指针不会在该函数范围之外产生任何影响。这样做:

int CreateBiTree(BiNode *T) { 
  /* ... */
  T = NULL;

和这样做是一样的:

int func(int i) { 
  /* ... */
  i = 0;

在这些情况下需要指向参数的指针:

int CreateBiTree(BiNode **T) { 
  /* ... */
  T[0] = NULL;  // or... *T = NULL;

对初始代码进行了一些更改:

int main() {
    BiNode *t; 
    CreateBiTree(&t);
    TraverseBiTree(t);
    return 0;
}

int CreateBiTree(BiNode **T) {          //create a binary tree by preorder traversal
    char tmp;
    scanf("%c", &tmp);
    if(tmp == ' ')
    T[0] = NULL;
    else {
        T[0] = (BiNode *)malloc(sizeof(BiNode));
        T[0]-> data = tmp;
        CreateBiTree(&(T[0]->lchild));
        CreateBiTree(&(T[0]->rchild));
    }   
    return 1;
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2019-08-23
    • 1970-01-01
    • 1970-01-01
    • 2016-05-01
    • 2013-07-23
    • 2013-05-12
    相关资源
    最近更新 更多