С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 20.02.2014
Сообщений: 1

Бинарное дерево

27.04.2014, 23:35. Показов 1174. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста с программой. Нужно сделать обход, слева и справа(функции get_left и get_right), желательно обход в глубину. И реализовать «подъем» на верхний уровень(функция root), т.е. получение корня.


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
100
#pragma once
#include "stdafx.h"
#include <iostream>
 
using namespace std;
 
class Dt
{
private: 
    Dt *up, *left, *right;
    int x;
public:
    Dt* add_left(int x)
    {
        if(left) delete left;
        Dt* dd = new Dt(x);
        left = dd;
        return left;
    }
    Dt* add_right(int x)
    {
        if(right) delete right;
        Dt* dd = new Dt(x);
        right = dd;
        return right;
    }
    
    
    //Dt* get_left()//получение эль-та справа ...                      
    void get_left(Dt *p, int level)
    {
        if(p)
        {
          get_left (p->left, level + 1);
        }
    }
    
    
    //Dt* get_rigt()
    void get_right (Dt *p, int level)
    {
        if(p)
        {
          get_right (p->left, level + 1);
        }
    }
    
    
    Dt* root()
    {
    }
    void insert(int x)
    {
        Dt *cc = this;
 
    }
    void set_x(int x)
    {
        if(x < Dt dt) add_left( x, Dt dt)//если Х меньше чем семечко(уходим влево)
    
        {
            Dt dt = new Dt(x);
            Dt dt->l = NULL;
            Dt dt->r = NULL;
            Dt dt-> x = x;
        }
        
        
        if(x > Dt dt) add_right( x, Dt dt)//если Х меньше чем семечко(уходим вправо)
        
        {
            Dt dt = new Dt(x);
            Dt dt->l = NULL;
            Dt dt->r = NULL;
            Dt dt-> x = x;*/
    }
    void print()
    {
        if(left) left->print();
        cout<<x<<" ";
        if (right) right->print();
    }
    Dt(void)
    { up=NULL;
        left=NULL;
        right=NULL;
    }
    Dt(int x)
    {
        up=NULL;
        left=NULL;
        right=NULL;
        this->x = x;
    }
    ~Dt(void)
    {
        delete left; 
        delete right;
    }
};
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.04.2014, 23:35
Ответы с готовыми решениями:

Исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру
Помогите, не могу понять!( Нужно исходное бинарное дерево превратить в бинарное дерево поиска, при этом сохранив его структуру. вот...

Бинарное дерево. Удалить из дерева часть вершин так, чтобы оставшееся дерево стало пирамидой
Дано бинарное дерево. Удалить из дерева часть вершин так, чтобы оставшееся дерево стало пирамидой.

Бинарное дерево
Здравствуйте.Прошу помощи.Никак не могу разобраться в задании.Нужно сделать бинарное дерево и с помощью дерева привести выражение к...

1
0 / 0 / 1
Регистрация: 17.03.2014
Сообщений: 6
25.05.2014, 12:01
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
.....
void Post_Order(Tree*Node)//обратный обход дерева
    {
        if (Node != NULL)
        {
            Post_Order(Node->left);
            Post_Order(Node->right);
            printf("%ed", Node->Data);
        }
    }
    void Order(Tree*Node)//симетрический проход дерева
    {
        if (Node != NULL)
        {
            Post_Order(Node->left);
            printf("%3ld", Node->Data);
            Post_Order(Node->right);
        }
    }
.....
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
25.05.2014, 12:01
Помогаю со студенческими работами здесь

Бинарное дерево
Здравствуйте.Прошу помощи.Никак не могу разобраться в задании.Нужно сделать бинарное дерево и с помощью дерева привести выражение к...

Бинарное дерево
Нужно записать в дерево и вывести в форматированном виде каталог файлов(типа windows) на вход даны имена файлов вида c:\win\1 ...

Бинарное дерево
Привет Делаю бинарное дерево, пытаюсь добавить элемент. Что делаю не так? Класс дерева struct node{ int data; //поле...

Бинарное дерево
Помогите исправить ошибку, компилятор ругается на 110 строку, не пойму почему( #include &lt;iostream&gt; #include &lt;cstdlib&gt; ...

Бинарное дерево
Подскажите алгоритм распечатки дерева на экран горизонтально, не вертикально, как обычно это делают. struct tree { int k;...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru