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

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

Войти
Регистрация
Восстановить пароль
 
Джирайя
3 / 3 / 0
Регистрация: 20.04.2010
Сообщений: 64
#1

Бинарное дерево - C++

22.05.2010, 23:37. Просмотров 340. Ответов 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
#include<stdlib.h>
#include<iostream.h>
#include<stdio.h>
#include<conio.h>
 
struct Node
{ int key;
Node *l;
Node *r;
};
 
typedef Node* NodePtr;
 
 
class kurs {
public:
 
void Tree();
 
private:
 
void BalanceTree(NodePtr& t, int n);
void SearchMax(NodePtr t, int *max);
void TreeOut( NodePtr t , int level);
void TreeDelete(NodePtr& t);
NodePtr BeforeMax (NodePtr t, int max);
 
};
 
void kurs::Tree()
{
clrscr();
NodePtr t;
int n, max=0;
t = NULL;
cout <<"\n\t Сбалансированное дерево \n";
cout <<"Введите кол-во элементов и элементы";
cin >>n;
BalanceTree(t, n);
cout <<"\n\n‚лў®¤:\n\n";
 
TreeOut( t,1 );
 
SearchMax(t,&max);
 
t=BeforeMax(t,max);
 
cout<<"\nЭлемент перед максимальным : "<<t->key;
getch();
}
 
 
void kurs::BalanceTree(NodePtr& t, int n)
{ int k, nl, nr;
  if (n == 0) t = NULL;
   else
   { nl = n / 2;
     nr = n-nl-1;
     cin >>k;
     t = new Node; t->key = k;
     BalanceTree(t->l, nl);
     BalanceTree(t->r, nr);
    }
}
 
void kurs::SearchMax(NodePtr t, int *max)
{
  if ( !t ) return;
  SearchMax(t->l,max);
  if (t->key>*max) *max=t->key;
  SearchMax(t->r,max);
}
 
void kurs::TreeOut( NodePtr t , int level)
{ int tab = 5;
if (t == NULL) cout <<"Дерево пусто ! \n";
 else
{ if (t->r != NULL) TreeOut(t->r, level+1);
   cout <<setw(tab*level) <<t->key <<endl;
       if (t->l != NULL) TreeOut(t->l, level+1);
}
}
 
NodePtr kurs::BeforeMax (NodePtr t, int max)
{ if (!t) return 0;
  if (BeforeMax(t->r,max));
  else {
  BeforeMax(t->l,max);
  if (t->l->key==max || t->r->key==max) return t;
  }
}
 
 
void main()
{
kurs go;
go.Tree();
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.05.2010, 23:37
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Бинарное дерево (C++):

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

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

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

Бинарное дерево - C++
Объясните пжлст почему не работает программа...при вводе файла пишет -842150451 /*Дан адрес P1 вершины дерева — записи типа TNode, ...

Бинарное дерево - C++
Доброго времени суток. Ребят, я не спец, требуется решить такую задачу: Написать нерекурсивную программу, печатающую все вершины...

Бинарное дерево - C++
Здравствуйте, нужно помощь в написании программы. Условие: Каждая вершина бинарного дерева содержит: - 2 указателя (на каждый...

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.05.2010, 23:37
Привет! Вот еще темы с ответами:

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

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

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

Бинарное дерево - C++
Помогите, пожалуйста. Осталась последняя задача в контрольной. Не знаю даже, как к ней подступиться. К проекту ПРИМЕР Btree ...


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

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

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