Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > C/C++ программирование > Общие вопросы C/C++
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 07.09.2011, 22:22   #1
maxim43k
Новичок
Джуниор
 
Регистрация: 07.09.2011
Сообщений: 7
Вопрос Дерево поиска

Дано дерево поиска, ключи которого – целые числа (положительные и отрицательные). Определить К-е «–»-е число, следующее за «+»-м числом при прямом просмотре дерева (TLR). У меня программа похоже вообще неправильно работает. Подскажите ошибки, пожалуйста. Помогите преобразовать эту программу в классы.

Код:
#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; }
}
maxim43k вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Дерево поиска на С++ maxim43k Помощь студентам 0 07.09.2011 21:50
Двоичное дерево поиска SkyArcher C# (си шарп) 0 21.05.2011 20:05
дерево двоичного поиска(С++) 1mposs1ble Помощь студентам 0 07.05.2010 16:05
Дерево цифрового поиска Alar Общие вопросы Delphi 2 10.07.2008 10:58