Форум программистов, компьютерный форум CyberForum.ru

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Вечный_Студент
2 / 2 / 0
Регистрация: 16.05.2012
Сообщений: 38
#1

Бинарное дерево с прямым обходом - C++

26.05.2012, 14:26. Просмотров 320. Ответов 1
Метки нет (Все метки)

Нашел на просторах вашего форуме код дерева с восходящим порядком прохождения

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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
#include <iostream>
#include <ctime>
#include <cstdlib>
 
using namespace std;
 
template<typename T> struct vertex{
T value;
vertex* left;
vertex* right;
};
 
template<typename T> void insert(vertex<T>* head, T element){
if(head->value == element) 
return;
else{
if(head->value < element){
if(head -> left == NULL){
head -> left = new vertex<T>;
head -> left -> value = element;
head -> left -> left = NULL;
head -> left -> right = NULL;
}
else{
head = head->left;
insert(head,element);
}
}
else
if(head->value > element){
if(head -> right == NULL){
head -> right = new vertex<T>;
head -> right -> value = element;
head -> right -> left = NULL;
head -> right -> right = NULL;
}
else{
head = head->right;
insert(head,element);
} 
}
}
 
}
template<typename T> int find (vertex<T>* head, T element, int *l)
{
if(head==NULL){
*l=0;
return *l;
}
if(head->value==element) return *l;
 
if (head->left) {
*l+=1;
find(head->left, element, l);
}
 
if (head->right) {
l+=1; 
find(head->right, element, l);
}
}
 
template<typename T> void show_bin_tree (vertex<T>* head, int n) 
{ 
if (head->left) 
show_bin_tree(head->left, n+1); 
 
for (int i = 0; i < n; i++) cout << " "; 
cout << head->value << '\n'; 
 
if (head->right) 
show_bin_tree(head->right, n+1); 
}
 
int main(){
 
vertex<char>* head = new vertex<char>;
head->left = NULL;
head->right = NULL;
srand(time(NULL));
head->value = (char)(rand()%('z'-'a')+'a');
 
 
const int max=9;
char arr[max], chr; int n=0;
bool b;
 
while (n<9){
b=true;
 
chr=(char)(rand()%('z'-'a')+'a');
 
for (int i=0; i<=n; i++){
if (arr[i]==chr){
b=false;
}
}
 
if (b){
arr[n]=chr;
++n;
}
}
 
 
for(int i = 0; i<9; i++)
insert(head,arr[i]);
 
cout << endl;
int l=0;
show_bin_tree (head, l);
 
char ch;
cin >> ch;
 
if(find(head, ch, &l))
cout << "Element found " << l;
else cout << "Element not found";
 
system("pause");
return 0;
}
вот что собственно программа выдает)
на дерево не очень похоже. кто объяснит как тут ветки то идут.
Миниатюры
Бинарное дерево с прямым обходом  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.05.2012, 14:26     Бинарное дерево с прямым обходом
Посмотрите здесь:

Несбалансированное бинарное дерево с рекурсивным обходом в обратном порядке - C++
добрый день. помогите пожалуйста с реализацией кода: .Несбалансированное бинарное дерево с рекурсивным обходом в обратном порядке (левое...

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

Бинарное дерево - C++
Разработать и реализовать на языке С следующие функции работой с бинарным деревом: 1. Создание пустого дерева 2. Добавление элемента в...

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

Бинарное дерево - C++
Как организовать вывод бинарного дерева?

Бинарное дерево - C++
Столкнулся с уникальной проблемой от которой волосы дыбом встают. Вот код, достаточно первой итерации цикла, я ввожу данные а потом...

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

Бинарное дерево - C++
Здравствуйте, Корень создаёться вот так TREE *root=NULL; непонятно почему функия добовления использует указатель на указатель ...

Бинарное дерево - C++
Мой код: Patient.h // // Created by User on 26.04.2016. // #ifndef LABA_10_PATIENT_H #define LABA_10_PATIENT_H using...

Бинарное дерево - C++
Только начал изучать тему &quot;деревья&quot;. Подскажите в чем ошибка)#include &lt;iostream&gt; using namespace std; struct Node{ int...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Вечный_Студент
2 / 2 / 0
Регистрация: 16.05.2012
Сообщений: 38
27.05.2012, 13:04  [ТС]     Бинарное дерево с прямым обходом #2
помогите =)
Yandex
Объявления
27.05.2012, 13:04     Бинарное дерево с прямым обходом
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru