Проблемы дерева BST - язык C - PullRequest
0 голосов
/ 30 июня 2018

Я пытаюсь создать дерево BST, используя язык C, более конкретно для упражнения в моем колледже. Программа должна прочитать из входного файла несколько целых чисел, выполнить некоторые операции с деревом и записать новые числа в другой файл (выходной файл).

Однако программа считывает только до пятой строки файла, а затем вылетает, вызывая код выхода 3221226356. Я не очень разбираюсь в указателях, поэтому мне нужна помощь в поиске ошибок.

Это код atm (код был плохо переведен, только названия функций, но вы, ребята, должны понять идею printf).

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

struct node
{
    int key;
    struct node *left, *right;
};

struct node *newNode(int item)
{
    struct node *temp =  (struct node *)malloc(sizeof(struct node));
    temp->key = item;
    temp->left = temp->right = NULL;
    return temp;
}


void inorder(struct node *root)
{
    if (root != NULL)
    {
        inorder(root->left);
        printf("%d\n", root->key);
        inorder(root->right);
    }
}

void increaseVector(int *vector_int, int size)
{
    int *temp = realloc(vector_int, ((int)(size+1) * sizeof(int)));
    if(temp == NULL){
        printf("Erro ao increaser o vector.\n");
    }
    else{
        vector_int = temp;
    }
}


struct node *insert(struct node* node, int key)
{   
    if (node == NULL) return newNode(key);

    if (key < node->key)
        node->left  = insert(node->left, key);
    else if (key > node->key)
        node->right = insert(node->right, key);   

    return node;
}

struct node *lesserNodeValue(struct node* node)
{
    struct node* currently = node;

    while (currently->left != NULL)
        currently = currently->left;

    return currently;
}

struct node *deleteNode(struct node* root, int key)
{
    if (root == NULL) return root;

    if (key < root->key)
        root->left = deleteNode(root->left, key);
    else if (key > root->key)
        root->right = deleteNode(root->right, key);
    else
    {
        if (root->left == NULL)
        {
            struct node *temp = root->right;
            free(root);
            return temp;
        }
        else if (root->right == NULL)
        {
            struct node *temp = root->left;
            free(root);
            return temp;
        }

        struct node *temp = malloc(sizeof(struct node));

        temp = lesserNodeValue(root->right);
        root->key = temp->key;
        root->right = deleteNode(root->right, temp->key);
    }
    return root;
}


int middleVector(int *vector, int size){
    if(size == 0){
        return 0;
    }
    else if(size%2 == 0){
        int middle = (int) size/2;
    }
    else{
        int middle = (int) (size-1)/2;
    }
}

void printFile(int *vector_int, int *size)
{
    printf("sizeanho do size: %d\n\n",*size);
    FILE *entrada;
    int tempor = 0;

    entrada = fopen("arquivo entrada.txt","r"); 
    if(entrada==NULL){
        printf("Erro ao abrir o arquivo");
    }
    else{
        while (fscanf(entrada, "%d", &tempor) != EOF)
        {  
            printf("sizeanho do size: %d\n\n",*size);
            increaseVector(vector_int, *size);
            printf("size antes de atribuir ao vector: %d\n\n",*size);
            vector_int[*size] = tempor;
            printf("tempor[%d] = %d\n",*size,tempor);
            *size = (int)*size+1;
        }
        printf("Saiu do WHILE\n\n");
        fclose (entrada);
    }
}

int main()
{
    struct node *root = NULL;   
    int *vector_int = (int *)malloc(NULL);
    int size = 0;
    int i;

    printFile(vector_int, &size); 
    printf("sizeanho apos printFile: %d\n\n",size);
    int posCentralVector = middleVector(vector_int,size);
    printf("middle do vector: %d\n\n", posCentralVector);
    root = insert(root, (int)vector_int[posCentralVector]);

    for(i=0; i<size; i++)
        if(vector_int[i] != root) insert(root, vector_int[i]);

    /*root = insert(root, 50);
    root = insert(root, 350);

    root = deleteNode(root, 10);
    root = deleteNode(root, 96);*/

    inorder(root);
}

Входной файл - это просто набор случайных полумесяц.

10 20 27 34 41 44 46 53 60 68 70 73 82 87 96 101 110 113 122 124 127 133 141 145 147 154 155 157 162 163

выход

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...