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

Дерево поиска - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как корректно вручную ввести данные http://www.cyberforum.ru/cpp-beginners/thread349134.html
Как реализовать ручной ввод в данной программе? (Задание: вставить заданный пользователем элемент Е до и после элемента с минимальным ключом в заданном пользователем односвязном списке.) #include...
C++ Вывод заданных чисел Для вывода цифр 1,2,3 в различных комбинациях дана программа #include<iostream> #include<stdlib.h> using namespace std; int main () {setlocale(LC_ALL,"Rus"); for(int i=1;i<4;i++) for(int... http://www.cyberforum.ru/cpp-beginners/thread349132.html
Отсутствие совместимости. C++
Дилема такова,что я не могу заметить ошибки именно в ходе решения(быть может со скобками переборщил),а точнее нахождения y1 и y2.Ответы должны быть аналогичными,заранее извиняюсь за отсутствие...
C++ С++ массив объектов
Люди начался новый учебный год опять обращаюсь за помощью File Имя файла.размер. количество обращений. создать массив объектов.ввывести. создать список файлов .размер которых превышает заданный....
C++ И снова палиндром http://www.cyberforum.ru/cpp-beginners/thread349116.html
Здравствуйте! У кого какие идеи на счет решения этой задачи? Палиндром — это строка, которая читается одинаково как справа налево, так и слева направо. Во входном файле записан набор больших...
C++ программа которая по номеру дня в году выводит число и месяц программа которая по номеру дня в году выводит число и месяц (например, 7-й день года — 7 января) что б при запуске появилось сообщение (Введите номер дня в году ) ну и вводим от 1 до 365... подробнее

Показать сообщение отдельно
maxistudent
0 / 0 / 0
Регистрация: 09.04.2010
Сообщений: 33

Дерево поиска - C++

07.09.2011, 22:16. Просмотров 306. Ответов 0
Метки (Все метки)

Дано дерево поиска, ключи которого – целые числа (положительные и отрицательные). Определить К-е «–»-е число, следующее за «+»-м числом при прямом просмотре дерева (TLR). У меня программа похоже вообще неправильно работает. Подскажите ошибки, пожалуйста. Помогите преобразовать эту программу в классы.
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
#include <iostream.h>
#include <iomanip.h>
#include <stdlib.h>
#include <conio.h>
 
struct Node     // узел дерева
 { int key;    // поле ключа узла
   Node *l; // поле ссылки на левую (left) ветвь из данного узла
   Node *r; // ...         на правую (right) ветвь  ...
 };
typedef Node* NodePtr; // тип - указатель на узел
 
void BalanceTree(NodePtr& t, int n);
// cтроит сбалансированное дерево (СД) из n элементов
 
void TreeOut( NodePtr t, int level=1 );
// выводит на экран дерево t от корня слева направо, level - номер
// уровня дерева, обращение: OutTree( t )
 
void LevelOut(NodePtr t, int m); // выводит на экран
// Massiv
 
void TreeDelete(NodePtr& t); // oсвобождает память, t <- NULL
 
void main()
{ NodePtr t, tl;
  int n, m;
  clrscr();
  t = NULL;
  cout <<"LR8 Сбалансированное  дерево.";
  cout <<"\nВведите число элементов n и элементы:\n";
  cin >>n;
 
  BalanceTree(t, n);
  TreeOut( t );  // исходное дерево
 
  cout <<"\nPlease, writeln the number of last Level: ";
  cin >>m;
  cout <<"\nMASSIV: ";
  LevelOut(t, m);
 
  TreeDelete(t);
  getch();
}
 
void BalanceTree(NodePtr& t, int n)  // cтроит
{ int k, nl, nr;   // сбалансированное дерево (СД) из n элементов
 
  if (n == 0) t = NULL;
   else
    { nl = n / 2;  // число узлов в левой ветви
      nr = n-nl-1;  //  то же      в правой ветви
        //  построения СД:
      cin >>k;                  // 1. Элемент "k" - корень ветви
      t = new Node; t->key = k;
      BalanceTree(t->l, nl);    // 2. Построить левую ветвь с nl узлами
      BalanceTree(t->r, nr);    // 3. Построить правую ветвь с nr узлами
    }
}
 
void TreeOut( NodePtr t, int level ) // вывод дерева t на экран
{ int tab = 5; // интервал табуляции между уровнями дерева
 
  if (t == NULL) cout <<"Дерево пусто ! \n";
   else
    { if (t->r != NULL) TreeOut(t->r, level+1); // pекурсивный спуск
                 //    до последнего элемента по правой ветви
      cout <<setw(tab*level*2) <<t->key <<endl;
      if (t->l != NULL) TreeOut(t->l, level+1);
    }
}
 
void LevelOut(NodePtr t, int m) // выводит на экран Massiv
 
{ if (t == NULL) cout <<"Дерево пусто ! \n";
  else
   { m = m-1;
     if (m>0 && t->l != NULL) LevelOut(t->l, m);
     if (m == 0) cout <<t->key <<' ';
     if (m>0 && t->r != NULL) LevelOut(t->r, m);
   }
}
void TreeDelete(NodePtr& t) // освобождает память, t <- NULL
{ if ( t != NULL )
   { TreeDelete(t->r); TreeDelete(t->l); delete t; t = NULL; }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru