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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Анализ и генерация случайных чисел http://www.cyberforum.ru/cpp-beginners/thread439252.html
Запрограммировать получение трёх последовательностей N случайных чисел (N={100,1000,10000}) с накоплением статистики о них . По результатам моделирования построить график распределения вероятностей . Помогите пожалуйста как сделать
C++ Помогите с синтаксисом Есть некий класс SomeClass. В процессе выполнения программы появляется неизвестное количество его экземпляров. Нужно собирать указатели на экземпляры этого класса и их количество: unsigned int InstanceCount = 0; SomeClass* Instances; Итак создаём: SomeClass* Instance = new SomeClass(); http://www.cyberforum.ru/cpp-beginners/thread439246.html
C++ Решение всех упражнений из книги Р. Лафоре "Объектно-ориентированное программирование в С++"
Хотя я и начинающий с++-шник. Хочу помочь другим людям. Здесь я буду выкладывать всё что мне удалось решить. В моих решениях будет много хедеров, делал я это в Dev C++. Ос Win 7 64 bit. Начнём со второй главы: #include <iostream> using namespace std; int main() {
C++ Конвертер текстового файла
Добрый день!!! Простите за наглость... Помогите пожалуйста написать программу-конвертер текстовых файлов из dos в windows и обратно. С командной строки должно вводится направление /d или /w. Я очень мало в этом понимаю. Заранее спасибо!!!
C++ Проблема с libmms - ошибка при компиляции. http://www.cyberforum.ru/cpp-beginners/thread439169.html
Здравствуйте. Уже который день не могу разобраться с упомянутой в заголовке библиотекой, а именно: пишу примерно такой тестовый код #include <iostream> #include <libmms/mms.h> int main() { mms_t *stream; char mms_link="mms://audio.rfn.ru/radiorus/audio/710/90.asf"; stream=mms_connect(0, 0, mms_link, 128);
C++ Привет. Как можна найти с даного примера умножение элементов массива с четными номерами? #include "stdafx.h" #include <stdlib.h> #include <stdio.h> #include <conio.h> #include <iostream> using namespace std; int main(int argc, _TCHAR* argv) подробнее

Показать сообщение отдельно
&Alex&
19 / 19 / 1
Регистрация: 21.03.2010
Сообщений: 221
01.02.2012, 21:11  [ТС]     Обратный обход
Кажется я понял как сделать. Можете проверить, правильно ли я выполнил все задания(в начале темы)? Вот программа:
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();
}
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru