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

Бинарные деревья: создание, отображение, поиск узлов - C++

Восстановить пароль Регистрация
 
vadiprog
2 / 2 / 0
Регистрация: 06.11.2011
Сообщений: 108
01.05.2012, 22:54     Бинарные деревья: создание, отображение, поиск узлов #1
Написать программу, которая выполняет следующие действия:

1. Генерирует с помощью генератора случайных чисел 10 символов латинского алфавита.
2. Из полученных символов строит упорядоченное бинарное дерево, отсортированный в заданном порядке в соответствии с направлением прохождения дерева.
3. Отображает полученное дерево на экране.
4. Осуществляет поиск среди элементов дерева значение введенного с клавиатуры и выводит на экран сообщение о номере найденного элемента согласно порядку прохождения дерева. Если такого элемента нет, то программа выводит сообщение о его отсутствии.


Порядок прохождения дерева - прямой.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.05.2012, 22:54     Бинарные деревья: создание, отображение, поиск узлов
Посмотрите здесь:

C++ бинарные деревья
Бинарные деревья C++
C++ Бинарные деревья
C++ бинарные деревья
бинарные деревья C++
Бинарные деревья C++
бинарные деревья С++ C++
Бинарные деревья и поиск по ним C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
taras atavin
Ушёл с форума.
 Аватар для taras atavin
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
02.05.2012, 12:49     Бинарные деревья: создание, отображение, поиск узлов #2
А есть ещё косой? Я знаю только такой:
C++
1
2
3
4
5
6
7
8
9
10
11
tree::f()
{
 if (left)
 {
  left-f();
 }
 if (right)
 {
  right-f();
 } 
}
. Кстати, требуется ли балансировка дерева, или сойдёт даже коряга из одной ветви? И почему 10? 4-х уровневое двоиное дерево допускает 15 узлов.
vadiprog
2 / 2 / 0
Регистрация: 06.11.2011
Сообщений: 108
02.05.2012, 14:18  [ТС]     Бинарные деревья: создание, отображение, поиск узлов #3
Вот код на восходящий порядок прохождения

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
124
#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;
 
}
Yandex
Объявления
02.05.2012, 14:18     Бинарные деревья: создание, отображение, поиск узлов
Ответ Создать тему
Опции темы

Текущее время: 06:59. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru