Предзаказ Итеративный обход - PullRequest
0 голосов
/ 29 октября 2018

Этот итеративный обход двоичного дерева продолжает давать мне ошибки ошибки сегментации, я не уверен, как назначить указатель для текущей переменной в дереве на извлеченный элемент из него, так как они 2 разных типов.

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);
}

1 Ответ

0 голосов
/ 29 октября 2018

Прямо сейчас вы помещаете целое число в стек, а затем пытаетесь открыть и присвоить его BTNode.Вы должны поместить BTNode в стек, поэтому, когда вы его вставите, вы можете получить данные.Я предполагаю, что это должно быть так;

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);
}

Это то, что вам нужно в конечном итоге исправить, но я не уверен, исправит ли это вашу ошибку ошибки сегментации.

...