• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Отладка программы на С++

  • Автор темы Автор темы b_Buty
  • Дата начала Дата начала

b_Buty

Ученик
Регистрация
26 Мар 2016
Сообщения
2
Реакции
0
Баллы
0
Отладка программы на С++

Написать программу на С++.
Дано бинарное дерево(заполняется с клавиатуры или из файла). Вывести значения всех вершин дерева в порядке обхода в ширину: вначале выводится корень, затем его потомки(слева направо), далее потомки второго уровня и тд.
Не могу правильно сделать обход((

#include <iostream>

using namespace std;

struct node
{
int data;
int lvl;
node *right, *left;
};

void Show(node *&MyTree)
{
if (MyTree != NULL)
{
if (MyTree->lvl == 0)
cout « MyTree->data « endl;
else
{
Show(MyTree->left);
Show(MyTree->right);
cout « endl;
}
}
}

void Create(int MyData, node *&MyTree, int level)
{
if (MyTree == NULL)
{
MyTree = new node;
MyTree->data = MyData;
MyTree->right = MyTree->left = NULL;
MyTree->lvl = level;
}
if (MyTree->left != NULL)
Create(MyData, MyTree->left, level+1);
else
{
MyTree->left = new node;
MyTree->left->left = MyTree->left->right = NULL;
MyTree->left->data = MyData;
MyTree->left->lvl = level;
}
if (MyTree->right != NULL)
Create(MyData, MyTree->right, level + 1);
else
{
MyTree->right = new node;
MyTree->right->left = MyTree->right->right = NULL;
MyTree->right->data = MyData;
MyTree->right->lvl = level;
}
}

void Del(node *&MyTree)
{
if (MyTree != NULL)
{
Del(MyTree->left);
Del(MyTree->right);
delete MyTree;
}
}

int main()
{
setlocale(LC_ALL, "rus");

node *Tree = NULL;
int *massiv, n;

cout « "Количество элементов:\t";
cin » n;
massiv = new int[n];
cout « "Введите элементы дерева:\n";
for (int i = 0; i < n; i++)
{
cin » massiv;
Create(massiv, Tree, 0);
}

system("cls");
cout « "Дерево в порядке обхода в ширину:\n";
Show(Tree);


Del(Tree);
delete[] massiv;
system("pause");
system("cls");
return 0;
}

[mod2]Уважаемый участник, на будущее: в соответствии с нашими Правилами, названия тем типа "Помогите!", "Help!!!", "Нужна помощь" и т.п. НЕ ДОПУСКАЮТСЯ, а темы, так названные, подлежат удалению.

Модератор[/mod2]
 
Назад
Сверху