20个元素的二叉搜索树

时间:2013-04-27 07:57:41

标签: binary-tree binary-search-tree

所以这个用于创建搜索和删除BST节点的代码效果很好,但只有当它的大小为9时,当我将SIZE更改为20时程序没有超过第一个打印时,如何使其大小为20语句,它说二进制树抱歉长代码。

#include <stdio.h>
#include <stdlib.h>


#define SIZE 9

typedef struct node
{
    int data;
    struct node* left;
    struct node* right;
} node;
 typedef int (*comparer)(int, int);
typedef void (*callback)(node*);


/*create a new node*/
node* create_node(int data)
{
    node *new_node = (node*)malloc(sizeof(node));
    if(new_node == NULL)
    {
        fprintf (stderr, "Out of memory!!! (create_node)\n");
        exit(1);
    }
    new_node->data = data;
    new_node->left = NULL;
    new_node->right = NULL;
    return new_node;
}

/*remove all nodes of the tree*/
void dispose(node* root)
{
    if(root != NULL)
    {
        dispose(root->left);
        dispose(root->right);
        free(root);
    }
}

/*search*/
node* search(node *root,const int data,comparer compare)
{
    if(root == NULL)
        return NULL;

    int r;
    node* cursor = root;
    while(cursor != NULL)
    {
        r = compare(data,cursor->data);
        if(r < 0)
            cursor = cursor->left;
        else if(r > 0)
            cursor = cursor->right;
        else
            return cursor;
    }
    return cursor;

}

/*delete a node*/
node* delete_node(node* root, int data,comparer compare)
{
    if(root == NULL)
        return NULL;

    node *cursor;
    int r = compare(data,root->data);
    if( r < 0)
        root->left = delete_node( root->left, data,compare);
    else if( r > 0 )
        root->right = delete_node(root->right,data,compare);
    else
    {
        if (root->left == NULL)
        {
            cursor = root->right;
            free(root);
            root = cursor;
        }
        else if (root->right == NULL)
        {
            cursor = root->left;
            free(root);
            root = cursor;
        }
        else 
        {
            cursor = root->right;
            node *parent = NULL;

            while(cursor->left != NULL)
            {
                parent = cursor;
                cursor = cursor->left;
            }
            root->data = cursor->data;
            if (parent != NULL)
                parent->left = delete_node(parent->left, parent->left->data,compare);
            else
                root->right = delete_node(root->right, root->right->data,compare);
        }
    }
    return root;
}

/*insert a new node*/
node* insert_node(node *root, comparer compare, int data)
{

    if(root == NULL)
    {
        root = create_node(data);
    }
    else
    {
        int is_left  = 0;
        int r        = 0;
        node* cursor = root;
        node* prev   = NULL;

        while(cursor != NULL)
        {
            r = compare(data,cursor->data);
            prev = cursor;
            if(r < 0)
            {
                is_left = 1;
                cursor = cursor->left;
            }
            else if(r > 0)
            {
                is_left = 0;
                cursor = cursor->right;
            }

        }
        if(is_left)
            prev->left = create_node(data);
        else
            prev->right = create_node(data);

    }
    return root;
}

/* compare two integers*/

int compare(int left,int right)
{
    if(left > right)
        return 1;
    if(left < right)
        return -1;
    return 0;
}

/*display a node's key*/

void display(node* nd)
{
    if(nd != NULL)
        printf("%d ",nd->data);
}

/*display tree or subtree*/

void display_tree(node* nd)
{
    if (nd == NULL)
        return;
    /* display node data */

    printf("%d",nd->data);
    if(nd->left != NULL)
        printf("(L:%d)",nd->left->data);
    if(nd->right != NULL)
        printf("(R:%d)",nd->right->data);
    printf("\n");

    display_tree(nd->left);
    display_tree(nd->right);
}


int main()
{
    node* root = NULL;
    comparer int_comp = compare;
    callback f = display;

    /* insert data into the tree */
    int a[SIZE];
    int i,b;

/* This takes the input from the user for the tree*/
    printf("\nPlease input the 20 numbers you want to summit to the TREE\n");
        for (b =0; b < SIZE; b++)
        {
        printf("#%2d > ", b+1);
        scanf("%d", &a[b]);
        }

    printf("--- C Binary Search Tree ---- \n\n");
    printf("Insert: ");
    for(i = 0; i < SIZE; i++)
    {
        printf("%d ",a[i]);
        root = insert_node(root,int_comp,a[i]);
    }
    printf(" into the tree.\n\n");

    /* display the tree */
    display_tree(root);

    /* remove element */
    int r;
    do
    {
        printf("Enter data to remove, (-1 to exit):");
        scanf("%d",&r);
        if(r == -1)
            break;
        root = delete_node(root,r,int_comp);
        /* display the tree */
        if(root != NULL)
            display_tree(root);
        else
            break;
    }
    while(root != NULL);

    /* search for a node */
    int key = 0;
    node *s;
    while(key != -1)
    {
        printf("Enter data to search (-1 to exit):");
        scanf("%d",&key);

        s = search(root,key,int_comp);
        if(s != NULL)
        {
            printf("Found it %d",s->data);
            if(s->left != NULL)
                printf("(L: %d)",s->left->data);
            if(s->right != NULL)
                printf("(R: %d)",s->right->data);
            printf("\n");
        }
        else
        {
            printf("node %d not found\n",key);
        }
    }

    /* remove the whole tree */
    dispose(root);
    return 0;
}

感谢您的帮助!

2 个答案:

答案 0 :(得分:0)

我尝试了你的代码,尝试将SIZE更改为20,并且在两种情况下都能正常工作。也许你改变了别的东西?此外,正如OGH所说,为什么首先将输入存储在数组中,消耗更多时间并限制输入的最大大小?

答案 1 :(得分:0)

无需将输入存储在数组中。在您从用户读取输入的代码部分中,只需将数字插入数组即可。我对C不太熟悉,但做了类似的事情:

int i;  
for (b =0; b < SIZE; b++)
  {
    printf("#%2d > ", b+1);
    scanf("%d", &i);
    root = insert_node(root, int_comp, i); 
  }

它在您的情况下正常工作,但如果您将大小更改为20,它会变得非常缓慢,这就是您认为它不起作用的原因。以这种方式执行将加快代码。