首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PreOrder迭代遍历

PreOrder迭代遍历
EN

Stack Overflow用户
提问于 2018-10-29 05:30:41
回答 1查看 112关注 0票数 0

这种迭代的二叉树遍历不断给我分段错误,我不确定如何将树中当前变量的指针分配给弹出的元素,因为它们是两种不同的类型。

代码语言:javascript
复制
struct BTnode{
     int data;
     struct BTnode* left;
     struct BTnode* right;
     struct BTnode* parent;
}; 
typedef struct BTnode BTnode_t; 


  typedef struct {
      LL_t* list;
  } stack_t;  //stack is created with a Linked List


void preOrderIter(BTnode_t* root)
{
    stack_t* s = stack_create();
    stack_push(s, root->data); 
    BTnode_t* current;

    while (!stack_is_empty(s))
    {
        current = stack_pop(s);
        printf("%d ", current->data); 

        if ( current->right != NULL)
            stack_push(s, current->right->data);

        if ( current->left != NULL)
            stack_push(s, current->left->data); 
    }

    free(s);
}
EN

回答 1

Stack Overflow用户

发布于 2018-10-29 05:55:48

现在,您正在将一个整数推送到堆栈,然后尝试弹出并将其分配给BTNode。您应该将BTNode推送到堆栈中,这样当您弹出它时,您就可以获得数据。我猜应该是这样的;

代码语言:javascript
复制
void preOrderIter(BTnode_t* root)
{
  stack_t* s = stack_create();
  stack_push(s, root); 
  BTnode_t* current;

  while (!stack_is_empty(s))
  {
    current = stack_pop(s);
    printf("%d ", current->data); 

    if ( current->right != NULL)
        stack_push(s, current->right);

    if ( current->left != NULL)
        stack_push(s, current->left); 
  }

  free(s);
}

这是你最终需要修复的东西,但我不确定这是否能修复你的分段错误。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53036257

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档