jeudi 1 avril 2021

error: implicit declaration of function 'elseif' is invalid in C99 in binary search tree. how can i solve this?

B_S_T.c:38:17: error: implicit declaration of function 'elseif' is invalid in C99 [-Werror,-Wimplicit-function-declaration] elseif(ptr == parptr->left) ^ B_S_T.c:38:44: error: expected ';' after expression elseif(ptr == parptr->left) ^ ; B_S_T.c:42:17: error: expected expression else ^ 3 errors generated. Why this code is giving me these 3 errors?

#include <stdio.h> 
#include <stdlib.h>
struct BST
{
    struct BST *left;
    int item;
    struct BST *right;
};void del(struct BST **r, int data)
{
    struct BST *ptr, *parptr, *pred, *parpred;
    if (*r == NULL)
        printf("Underflow");
    else
    {
        parptr = NULL;
        ptr = *r;
        while (ptr->item != data && ptr != NULL)
        {
            if (ptr->item > data)
            {
                parptr = ptr;
            }
            else
            {
                parptr = ptr;
                ptr = ptr->right;
            }
        }
        if (ptr == NULL)
            printf("Data not found");
        else
        {
            if (ptr->left == NULL && ptr->right == NULL)
            {
                if (parptr == NULL)
                    *r = NULL;
                elseif(ptr == parptr->left)
                {
                    parptr->left = NULL;
                }
                else
                {
                    parptr->right = NULL;
                }
                free(ptr);
            }
            else if (ptr->left == NULL || ptr->right == NULL)
            {
                if (parptr == NULL)
                {
                    if (ptr->left != NULL)
                        *r = ptr->left;
                    else
                        *r = ptr->right;
                }
                if (ptr == parptr->left)
                {
                    if (ptr->left != NULL)
                        parptr->left = ptr->left;
                    else
                        parptr->left = ptr->right;
                }
                else
                {
                    if (ptr->left != NULL)
                        parptr->right = ptr->left;
                    else
                        parptr->right = ptr->right;
                }
                free(ptr);
            }
            else
            {
                pred = ptr->left;
                parpred = ptr;
                while (pred->right != NULL)
                {
                    parpred = pred;
                    pred = pred->right;
                }
                ptr->item = pred->item;
                if (pred == parpred->left)
                {
                    parpred->left = pred->left;
                }
                else
                {
                    parpred->right = pred->left;
                }
                free(pred);
            }
        }
    }
}
void insert(struct BST **r, int data)
{
    struct BST *n, *ptr;
    n = (struct BST *)malloc(sizeof(struct BST));
    n->item = data;
    n->left = NULL;
    n->right = NULL;
    if (*r == NULL)
        *r = n;
    else
    {
        ptr = *r;
        while (1)
        {
            if (ptr->item == data)
            {
                printf("Duplicate item cannot be inserted");
                free(n);
                break;
                //duplicate data
            }
            else if (ptr->item > data)
            {
                if (ptr->left == NULL)
                {
                    ptr->left = n;
                    break;
                }
                else
                    ptr = ptr->left;
                //insert in left sub tree
            }
            else
            {
                if (ptr->right == NULL)
                {
                    ptr->right = n;
                    break;
                }
                else
                    ptr = ptr->right;
                //insert in right sub tree
            }
        }
    }
}
//traversing
void postorder(struct BST *root)
{
    if (root != NULL)
    {
        if (root->left != NULL)
            postorder(root->left);
        if (root->right != NULL)
            postorder(root->right);
        printf("%d ", root->item);
    }
}

void preorder(struct BST *root)
{
    if (root != NULL)
    {
        printf("%d ", root->item);
        if (root->left != NULL)
            preorder(root->left);
        if (root->right != NULL)
            preorder(root->right);
    }
}

void inorder(struct BST *root)
{
    if (root != NULL)
    {
        if (root->left != NULL)
            inorder(root->left);
        printf("%d ", root->item);
        if (root->right != NULL)
            inorder(root->right);
    }
}

int main()
{
    struct BST *root = NULL;
    int data = 50;
    insert(&root, 50);
    insert(&root, 70);
    insert(&root, 30);
    insert(&root, 60);
    insert(&root, 40);
    insert(&root, 10);
    del(&root, data);
    printf("\nPreorder: ");
    preorder(root);
    printf("\nIorder: ");
    inorder(root);
    printf("\nPostorder: ");
    postorder(root);
    return 0;
}

Aucun commentaire:

Enregistrer un commentaire