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

Обратный обход - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.80
&Alex&
 Аватар для &Alex&
19 / 19 / 1
Регистрация: 21.03.2010
Сообщений: 221
01.02.2012, 19:08     Обратный обход #1
У меня есть реализация дерева и его прямой и симметричный обход. Как можно реализовать обратный обход?
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
#include "stdafx.h"
#include <iostream>
using namespace std;
 
struct TREE {
int info;
 TREE *right,*left;
 };
 
TREE *root=NULL;
int count=0; 
 
void Create(TREE **current, int n)
 {
if(n==0)
 *current=NULL;
else
 {
int nl=n/2;
int nr=n-nl-1;
 TREE *tmp=new TREE;
 count++;
 tmp->info=rand()%100;
 Create(&tmp->left,nl);
 Create(&tmp->right,nr);
 *current=tmp;
 }
}
 
void ShowSymmetric(TREE *current,int l)
 {
if(current!=NULL)
 {
 ShowSymmetric(current->left, l+1);
for(int i=0; i<l; i++)
 cout << "->";
 cout << current->info;
 ShowSymmetric(current->right, l+1);
 }
 }
 
void ShowOnward(TREE *current, int l)
 {
if(current!=NULL)
 {
for(int i=0; i<l; i++)
 cout << "->";
 cout << current->info ;
 ShowOnward(current->left, l+1);
 ShowOnward(current->right, l+1);
 }
 }
 
int main()
 {
 setlocale(LC_ALL,"Russian");
char otv;
int n;
do
 {
 cout << endl<< "1. Создать дерево" << endl
 << "2. Обход в прямом направлении" << endl
 << "3. Симметричный обход" << endl
 << "0. Выход" << endl
 << " = ";
 cin >> otv;
switch(otv)
 {
case '1':
 cout << endl << "Введите число вершин = ";
 cin >> n;
 Create(&root, n);
break;
case '2':
if(count==0)
 cout << endl << "Дерево пустое" << endl;
else
 ShowOnward(root, 0);
break;
case '3':
if(count==0)
 cout << endl << "Дерево пустое" << endl;
else
 ShowSymmetric(root, 0);
break;
case '0':
break;
default:
 cout << endl << "Ошибка" << endl;
break;
}
}while(otv!='0');
 cin.get();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.02.2012, 19:08     Обратный обход
Посмотрите здесь:

C++ Бинарное дерево. Обход бинарного дерева (симметрический, прямой и обратный)
Обратный порядок C++
Обратный порядок.. C++
C++ Обратный корень
Обратный корень C++
Разница между понятиями "Обход в прямом направлении" и "Итерационный прямой обход" C++
Обратный порядок С++ C++
Обратный код C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
01.02.2012, 19:51     Обратный обход #2
ABR
C++
1
2
3
4
5
6
7
8
9
void iteration(node* &root)
{
    if ( root )
    {
        iteration( root->left );
        iteration (root->right );
            std::cout << root->key << std::endl;
    }
}
&Alex&
 Аватар для &Alex&
19 / 19 / 1
Регистрация: 21.03.2010
Сообщений: 221
01.02.2012, 21:11  [ТС]     Обратный обход #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
#include "stdafx.h"
#include <iostream>
using namespace std;
 
struct TREE {
int info;
 TREE *right,*left;
 };
 
TREE *root=NULL;
int count=0; 
 
 
//создание дерева
void Create(TREE **current, int n)
 {
if(n==0)
 *current=NULL;
else
 {
int nl=n/2;
int nr=n-nl-1;
 TREE *tmp=new TREE;
 count++;
 tmp->info=rand()%100;
 Create(&tmp->left,nl);
 Create(&tmp->right,nr);
 *current=tmp;
 }
}
//обратный обход
void obr(TREE *current)
 {
if(current!=NULL)
 {
 obr(current->left);
 cout << "->";
 obr(current->right);
  cout << current->info ;
 }
}
//симметрический обход
void ShowSymmetric(TREE *current,int l)
 {
if(current!=NULL)
 {
 ShowSymmetric(current->left, l+1);
 cout << "->";
 cout << current->info;
 ShowSymmetric(current->right, l+1);
 }
 }
//прямой обход
void ShowOnward(TREE *current)
 {
if(current!=NULL)
 {
 cout << "->";
 cout << current->info ;
 ShowOnward(current->left);
 ShowOnward(current->right);
 }
}
 
int main()
 {
 setlocale(LC_ALL,"Russian");
char otv;
int n;
do
 {
 cout << endl<< "1. Создать дерево" << endl
 << "2. Обход в прямом направлении" << endl
 << "3. Симметричный обход" << endl
 << "4. Обход в обратном направлении" << endl
 << "0. Выход" << endl
 << " = ";
 cin >> otv;
switch(otv)
 {
case '1':
 cout << endl << "Введите число вершин = ";
 cin >> n;
 Create(&root, n);
break;
case '2':
if(count==0)
 cout << endl << "Дерево пустое" << endl;
else
 ShowOnward(root);
break;
 
case '4':
if(count==0)
 cout << endl << "Дерево пустое" << endl;
else
obr(root);
break;
 
case '3':
if(count==0)
 cout << endl << "Дерево пустое" << endl;
else
 ShowSymmetric(root, 0);
break;
case '0':
break;
default:
 cout << endl << "Ошибка" << endl;
break;
}
}while(otv!='0');
 cin.get();
}
Yandex
Объявления
01.02.2012, 21:11     Обратный обход
Ответ Создать тему
Опции темы

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