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

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

Войти
Регистрация
Восстановить пароль
 
vadiprog
2 / 2 / 0
Регистрация: 06.11.2011
Сообщений: 108
#1

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

01.05.2012, 22:54. Просмотров 726. Ответов 2
Метки нет (Все метки)

Написать программу, которая выполняет следующие действия:

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


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

Бинарные деревья и поиск по ним - C++
Необходимо создать программу для дисциплины ИИ Задача - в поле 4х4 есть игрок и 3 блока (А,Б и С). Начальное состояние задается руками в...

Бинарные деревья на С++ - C++
пишу программу в Dev-C++ для работы с бинарными деревьями. возникла такая проблема: функция FindTree возвращает отрицательное значение,...

Бинарные деревья - C++
Разработать набор классов упорядоченных бинарных деревьев поиска типов: вещественные числа, двоичные строки(строка из 0 и 1) и линейные...

бинарные деревья - C++
Здравствуйте! Помогите пожалуйста доделать задачу на бинарные деревья. Язык только начали изучать. Дается не очень легко. Пока...

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

Бинарные деревья - C++
Компилятор выдаёт ошибки в 9, 10 и 12, 13 строках: invalid conversion from 'int' to 'sNode*' Подскажите пожалуйста, что не так. ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
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;
 
}
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.05.2012, 14:18
Привет! Вот еще темы с ответами:

бинарные деревья - C++
Вот у меня есть программа, которая создает бинарное дерево из массива целых чисел. #include &lt;iostream&gt; #include &lt;conio.h&gt; using...

Бинарные деревья - C++
Здравствуйте! Подскажите, правильно ли написано правое удаление вершины дерева? if(tree1-&gt;Right){ if(tree1-&gt;Right-&gt;Left==NULL){ ...

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

Бинарные деревья С++ - C++
Добрый день! Дали такое задание на лабораторную работу. кое-что получилось, а в остальном прошу Вас помочь... Из входной...


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

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