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

По поводу дерева - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.69
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
06.09.2011, 20:55     По поводу дерева #1
"Дано дерево поиска, ключи которого – целые числа (положительные и отрицательные). Определить К-е отрицательное число, следующее за положительным числом при прямом просмотре дерева (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
#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 <<"MASSIV: ";
  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; }
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.09.2011, 20:55     По поводу дерева
Посмотрите здесь:

C++ По поводу грамматики
По поводу рекурсии C++
C++ Вопрос по поводу кода
C++ По-поводу кейлоггера
C++ Вывод бинарного дерева на экран в виде "дерева"
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
09.09.2011, 11:33  [ТС]     По поводу дерева #41
Всё равно не работает

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
#include <iostream.h>
#include <iomanip.h>
#include <stdlib.h>
#include <conio.h>
 
struct Node
{int key;
 Node *l;
 Node *r;
};
 
typedef Node* NodePtr;
int rez;
int flag=0;
int m = 2;
int k;
 
void AddTree(NodePtr& t, int k); //добавляет элемент k в рядоченное
void TreeOut( NodePtr t, int level=1 );//выводит на экран дерево
void TreeDelete(NodePtr& t); //oсвобождает память
void f(NodePtr t);
 
void main()
{clrscr();
 NodePtr t;
 int n, e;
 cout << "Введите ключ К: ";
 cin >> n;
 t = NULL;
 cout << "\nУпорядоченное  дерево: \n";
 cout <<"Bведите числа, конец ввода - Ctrl+Z, Enter: ";
 while ( cin >> e ) AddTree(t, e); // формирование дерева
 cout << endl;
 TreeOut( t );
 cout <<"\nНисходящий метод прохода дерева: ";
 k = 2;
 f(t);
 TreeDelete(t);
 if(rez==0) cout << "\nОшибка!";
 else cout << endl << "Результат: " << rez;
 getch();
}
 
void f(NodePtr t)
{
    if (t == NULL || k <= 0)
        return;
    if (t->key < 0)
        k--;
    if (k == 0) {
        cout << t->key << endl;
        rez = t->key;
        return;
    }
    TreeOut(t->l);
    TreeOut(t->r);
}
 
void AddTree(NodePtr& t, int k)
{if (t == NULL) //Если t=NULL, то добавить элемент k в дерево
  {t = new Node;
   t->l = NULL;
   t->r = NULL;
   t->key = k;
  }
 else //Если k >= t->key, то
  {
   if (k >= t->key) AddTree(t->r, k);  //двигаться в правую ветвь,
   if (k <  t->key) AddTree(t->l, k);  //иначе - в левую ветвь
  }
}
 
void TreeOut( NodePtr t, int level ) //вывод дерева на экран
{int tab = 5; // интервал табуляции между уровнями дерева
 if (t == NULL) cout << "Дерево пусто! \n";
 else {if (t->r != NULL) TreeOut(t->r, level+1); // pекурсивный спуск
                //до последнего элемента по правой ветви
       cout <<setw(tab*level) <<t->key <<endl;
       if (t->l != NULL) TreeOut(t->l, level+1);
      }
}
 
void TreeDelete(NodePtr& t) // освобождает память, t <- NULL
{if (t != NULL)
  {TreeDelete(t->r);
   TreeDelete(t->l);
   delete t;
   t = NULL;
  }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
accept
4838 / 3237 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
09.09.2011, 11:36     По поводу дерева #42
вот теперь вывод покажи
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
09.09.2011, 11:51  [ТС]     По поводу дерева #43
По поводу дерева
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
10.09.2011, 00:34  [ТС]     По поводу дерева #44
Ну как сделать так, чтобы программа работала нормально?

Добавлено через 3 часа 36 минут
Как этот код в класс загнать?
accept
4838 / 3237 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
10.09.2011, 06:31     По поводу дерева #45
рекурсивная функция была составлена с остаточными вызовами
теперь всё переделано на локальные переменные
вывод
Код
[guest@localhost tests]$ cat tree.txt | ./t
Введите ключ К: 
Упорядоченное  дерево: 
Bведите числа, конец ввода - Ctrl+Z, Enter: 
                        6
                   5
              5
         5
                   2
              2
    2
              1
         1
                            -1
                       -2
                  -3
                                 -4
                            -4
                       -6
             -6
                  -9

Нисходящий метод прохода дерева: 

Результат: -9
[guest@localhost tests]$ cat tree2.txt | ./t
Введите ключ К: 
Упорядоченное  дерево: 
Bведите числа, конец ввода - Ctrl+Z, Enter: 
              3
         2
    1
        -1
             -2
                  -3

Нисходящий метод прохода дерева: 

Результат: -3
[guest@localhost tests]$
Вложения
Тип файла: zip tree_negat.zip (2.0 Кб, 8 просмотров)
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
10.09.2011, 08:28  [ТС]     По поводу дерева #46
А вот так правильно класс организовывать?

*.cpp
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
#include "TREE"
 
int main()
{
 TREE str;
 return 0;
}
 
 TREE::TREE()
{
  NodePtr t;
  int k, e, rez;
  clrscr();
  cout << "Введите ключ К: ";
  cin >> k;
  cout << "\nУпорядоченное  дерево: \n";
  cout << "Bведите числа, конец ввода - Ctrl+Z, Enter: ";
  t = NULL;
  while (cin >> e)
  
  AddTree(t, e); // формирование дерева
  cout << endl;
  TreeOut(t);
  cout << "\nНисходящий метод прохода дерева: " << endl;
  TreeFindNegative(t, k, rez);
  TreeDelete(t);
  
  if (rez == 0) cout << "\nОшибка!" << endl;
  else cout << endl << "Результат: " << rez << endl;
  getch();
}
 
void TREE::TreeFindNegative(NodePtr t, int k, int &rez)
{
  static int n = 0;
 
  if (t == NULL || n >= k) return;
    if (t->key < 0) n++;
       if (n == k) 
         {
          rez = t->key;
          return;
         }
  TreeFindNegative(t->l, k, rez);
  TreeFindNegative(t->r, k, rez);
}
 
void TREE::AddTree(NodePtr &t, int k)
{
  if (t == NULL)
  { //Если t=NULL, то добавить элемент k в дерево
    t = new Node;
    t->key = k;
    t->l = t->r = NULL;
  } 
 else 
  { //Если k >= t->key, то
   if (k >= t->key) AddTree(t->r, k);  //двигаться в правую ветвь,
   else AddTree(t->l, k);  //иначе - в левую ветвь
  }
}
 
void TREE::TreeOut(NodePtr t, int level) //вывод дерева на экран
{
  int tab = 5; // интервал табуляции между уровнями дерева
 
  if (t == NULL)
  cout << "Дерево пусто! \n";
  else 
     {
      if (t->r != NULL) TreeOut(t->r, level + 1); // pекурсивный спуск
                      //до последнего элемента по правой ветви
 
      cout << setw(tab * level) << t->key << endl; 
 
      if (t->l != NULL) TreeOut(t->l, level + 1);
    }
}
 
void TREE::TreeDelete(NodePtr& t) // освобождает память, t <- NULL
{
    if (t != NULL) 
   {
     TreeDelete(t->r);
     TreeDelete(t->l);
     delete t;
     t = NULL;
   }
}
*.h
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
#include <iostream.h>
#include <iomanip.h>
#include <stdlib.h>
#include <conio.h>
 
 class TREE
{
  struct Node 
 {
   int key;
   Node *l, *r;
 };
 
 
 public:
    TREE();
    ~TREE();
    typedef Node *NodePtr;
        
 private:
    void TREE::TreeFindNegative(NodePtr t, int k, int &rez);
    void TREE::AddTree(NodePtr &t, int k);
    void TREE::TreeOut(NodePtr t, int level);
    void TREE::TreeDelete(NodePtr& t); 
}
accept
4838 / 3237 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
10.09.2011, 08:37     По поводу дерева #47
C++
1
NodePtr t;
это должно быть в описании класса, а не в конструкторе
конструктор не должен включать всякие действия, которые не относятся к созданию экземпляра
всё, что было в main(), должно остаться в main()

ты в чём редактируешь код ?
ты внутри этой фигни код не редактируй, пиши его в обычном блокноте, или в notepad++
а в этой фигне просто подключай эти файлы и компилируй
(иначе любой нормальный код превращается в свалку)
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
10.09.2011, 08:40  [ТС]     По поводу дерева #48
BC 3.1
accept
4838 / 3237 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
10.09.2011, 08:43     По поводу дерева #49
BC 3.1 == фигня
это никая среда
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.09.2011, 08:58     По поводу дерева
Еще ссылки по теме:

C++ По поводу расширения окна
Написать шаблон бинарного дерева с функцией распечатки дерева C++
По поводу библиотек и их подключения C++

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

Или воспользуйтесь поиском по форуму:
maxim43k
0 / 0 / 0
Регистрация: 04.09.2011
Сообщений: 106
10.09.2011, 08:58  [ТС]     По поводу дерева #50
Я знаю, но иначе никак, я в универе учусь

Добавлено через 13 минут
Всё равно отладить не получается
Yandex
Объявления
10.09.2011, 08:58     По поводу дерева
Ответ Создать тему
Опции темы

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