在c中以递归方式插入单个链表

时间:2017-06-13 21:09:24

标签: c tree insert binary-tree

有谁能告诉我我的代码有什么问题?
我想创建非返回函数void以在链表的末尾插入一个节点。

void insert_tail_Recursively(struct node **phead, int key) {
  if (*phead == NULL) {
    Node*temp = malloc(sizeof(Node));
    temp->data = key;
    temp->pLeft = temp->pRight = NULL;
    *phead = temp;
  } else {
    Node*temp = malloc(sizeof(Node));
    temp->data = key;
    temp->pLeft = temp->pRight = NULL;

    /* data more than root node data insert at right */
    if ((temp->data > (*phead)->data) && ((*phead)->pRight != NULL)) 
      insert_tail_Recursively((*phead)->pRight, key);
    else if ((temp->data > (*phead)->data) && ((*phead)->pRight == NULL)) {
      (*phead)->pRight = temp;

    }

    /* data less than root node data insert at left */
    else if ((temp->data < (*phead)->data) && ((*phead)->pLeft != NULL)) 
      insert_tail_Recursively((*phead)->pLeft, key);
    else if ((temp->data < (*phead)->data) && ((*phead)->pLeft == NULL)) {
      (*phead)->pLeft = temp;
    }
  }
}

1 个答案:

答案 0 :(得分:1)

您的代码太复杂,结果有错误。例如,存在内存泄漏。

看来你的意思如下。

void insert_tail_Recursively( struct node **phead, int key )
{
    if ( *phead == NULL )
    {
        *phead = malloc( sizeof( struct node ) );
        ( *phead )->data = key;
        ( *phead )->pLeft = ( *phead )->pRight = NULL;
    }
    else
    {
        phead = key < ( *phead )->data ? &( *phead )->pLeft : &( *phead )->pRight;
        insert_tail_Recursively( phead, key );
    }
}