Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 Аватар для Mayki_2301
0 / 0 / 0
Регистрация: 14.05.2022
Сообщений: 69

С исходной последовательности целых чисел построить бинарное дерево поиска

13.12.2022, 16:33. Показов 467. Ответов 0

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

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <iostream>
 
using namespace std;
 
struct BinaryTree {
    int data;
    BinaryTree* left, * right;
};
// создание первого узла дерева
BinaryTree* First(int x) {
    BinaryTree* pv = new BinaryTree;
    pv->data = x;
    pv->left = 0;
    pv->right = 0;
    return pv;
}
 
BinaryTree* Search_Insert(BinaryTree* q, int x) {
    BinaryTree* pv = q, * prev = 0;
    bool found = false;
    while (pv && !found)
    {
        prev = pv;
        if (x == pv->data) found = true;
        else if (x < pv->data)
            pv = pv->left;
        else pv = pv->right;
    }
    if (found)  return pv;
        BinaryTree* pnew = new BinaryTree;
    pnew->data = x;
    pnew->left = 0;
    pnew->right = 0;
    if (x < prev->data) prev->left = pnew;
    else prev->right = pnew;
    return pnew; 
}
 
void Print_BinaryTree(BinaryTree* q, int n) {
    if (q)
    {
        int i;
        Print_BinaryTree(q->left, n + 5);
        for (i = 0; i < n; i++) 
            printf(" ");
        printf("%d", q->data);
        printf("\n");
        Print_BinaryTree(q->right, n + 5);
    }
}
 
void Delete_BinaryTree(BinaryTree* q) {
    if (q != NULL)
    {
        Delete_BinaryTree(q->left);
        Delete_BinaryTree(q->right);
        delete q;
    }
}
 
int sum_BinaryTree(BinaryTree* q) {
    int l, r;
    if (q != NULL)
    {  
        l = (q->left != NULL) ? sum_BinaryTree(q->left) : 0;
        r = (q->right != NULL) ? sum_BinaryTree(q->right) : 0;
        return l + r + q->data;
    }
    return 0;
}
BinaryTree* min_BinaryTree(BinaryTree* q) {
 
    if (q->left == NULL) return q;
    return min_BinaryTree(q->left);
 
}
 
int main()
{
    int i, n = 0;
    
    int a[10] = { 1, -2, 3, 4, 15, 6, -7, 8, 0, 10 };
    
    BinaryTree* root = NULL;
    for (i = 0; i < 10;i++)
        if (root == 0) root = First(a[i]);
        else Search_Insert(root, a[i]);
    printf("Binary Tree=\n");
    Print_BinaryTree(root, n);
    printf("count level=%d \n", n);
 
    printf("avg= %5.2f\n", (float)sum_BinaryTree(root) / 10);
    printf("\n");
    BinaryTree* x = min_BinaryTree(root);
    printf("min= %d\n", x->data);
    Delete_BinaryTree(root);
 
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.12.2022, 16:33
Ответы с готовыми решениями:

Построить бинарное дерево поиска из входной последовательности целых чисел. Вывести всех детей трехзначных узлов
Построить бинарное дерево поиска из входной последовательности целых чисел. Вывести всех детей трехзначных узлов. Язык: (С++)

Из входной последовательности целых чисел построить бинарное дерево поиска
Ребят помогите решить задачу // Из входной последовательности целых чисел построить бинарное дерево поиска. Определить количество узлов...

Ввести 10-15 целых чисел и построить из них бинарное дерево поиска
Ввести 10-15 целых чисел и построить из них бинарное дерево поиска . Хелп плиз , вообще не вкуриваю по этим бинарным деревьям ... не упали...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.12.2022, 16:33
Помогаю со студенческими работами здесь

Из входной последовательности символов построить бинарное дерево поиска
как из входной последовательности символов построить бинарное дерево поиска. Подскажите пожалуйста.

Дана последовательность чисел. Построить бинарное дерево поиска, содержащее эти числа. С++
Дана последовательность чисел. Построить бинарное дерево поиска, содержащее эти числа. Для числа, введённого с клавиатуры, сказать,...

Дана последовательность чисел Построить бинарное дерево поиска, содержащее эти числа
2: Дана последовательность чисел. Построить бинарное дерево поиска, содержащее эти числа. Для числа введённого с клавиатуры произвести...

На основе вводимой с клавиатуры последовательности чисел до первого нуля формируется бинарное дерево поиска
Страшно каюсь, не подумайте что я ленивый тюлень и мне не хочется вникать в тему, обычно я никогда так не делала, но у меня не осталось...

Построить бинарное дерево поиска из чисел входного потока. Повторяющиеся значения узлов указывать в виде счетчика
Ребята, помогите, пожалуйста. Нужно срочно сделать! Построить бинарное дерево поиска из чисел входного потока. Повторяющиеся значения...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru