Nano Hash - криптовалюты, майнинг, программирование

Что за ошибка в этом коде?

Я инициализировал корень в NULL при запуске, и то же самое будет с первой функцией вставки. Поскольку я отправил адрес корня, он должен быть изменен, но это не так, снова во втором операторе вставки NULL vakue для корня происходит внутри функции вставки.

Пожалуйста, дайте мне знать, где я пропустил это.

#include <stdio.h>
#include <stdlib.h>
typedef struct bst{
    struct bst *left;
    int data;
    struct bst *right;
}bst_t;

void insert(struct bst**, int);
void print(struct bst*);


int main() {
    struct bst *root;
    root = NULL;

    insert(&root, 45);
    insert(&root, 75);
    insert(&root, 5);
    insert(&root, 76);
    insert(&root, 25);
    insert(&root, 56);
    insert(&root, 89);
    insert(&root, 99);
    insert(&root, 98);

    print(root);

    printf("Print Any Char...\n");
    getch();
    return 0;
}

void insert(struct bst **root, int num)
{
    struct bst *node = *root;

    if(node == NULL)
    {
        node = (struct bst*)malloc(sizeof(struct bst));
        node->left  = NULL;
        node->data  =   num;
        node->right = NULL;
        return;
    }
    else
    {
        if(num < node->data)
        {
            insert(&(node->left), num);
        }
        else
        {
            insert(&(node->right), num);
        }
    }
    return;
}

void print(struct bst *root)
{
    struct bst *temp = root;

    if(temp != NULL)
    {
        printf("%d --> ", temp->data);
        print(temp->left);
        print(temp->right);
    }
    else
    return;
}
30.03.2017

  • Вам необходимо прочитать это ericlippert.com/2014/03/ 05/как отлаживать небольшие программы 30.03.2017
  • Подсказка: внимательно посмотрите на код, который вы выполняете, чтобы вставить первый узел в пустое дерево. Не хватает задания. 30.03.2017
  • Подсказка 2: избегайте особых случаев. Вам нужно только найти (указатель на) указатель NULL и назначить ему новый узел. 30.03.2017

Ответы:


1

Вы делаете локальную копию корневого указателя:

struct bst *node = *root;

Затем вы можете изменить его:

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

К сожалению, вы не передаете это изменение обратно вызывающей стороне, поэтому оно теряется :(

Пытаться:

*root=node;

в конце.

Сильно подозреваю, что именно на это и намекал @ Какой-то чувак-программист в своем комментарии :)

30.03.2017
Новые материалы

Кластеризация: более глубокий взгляд
Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

Как написать эффективное резюме
Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

Частный метод Python: улучшение инкапсуляции и безопасности
Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

Как я автоматизирую тестирование с помощью Jest
Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

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

Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..