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

Бинарное Дерево(обход дерева) - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 14, средняя оценка - 4.71
lolers
0 / 0 / 0
Регистрация: 16.04.2010
Сообщений: 14
22.04.2010, 21:14     Бинарное Дерево(обход дерева) #1
добрый вечер всем!)
в универе задали написать бинарное дерево со всеми видами обхода и т.п. я их написал..
но еще дали 1 вывод его надо написать рекурсией, я его никак не могу реализовать.
поясняю:
например дерево:
7
/ \
6 8
надо вывести его в таком виде, но еще это дерево должно лежать на левом боку(просто нарисовать так трудно, написал так):

7
/ \
6 8
/ \ / \
@ @ @ @
т.е есть там где NULL вывести "@";

struct tree_node{ int val; tree_node *left,*right;}; - элемент дерева.
вот что до чего я дошел, только без выводов @..а просто дерево лежащее на левом боку.
C++
1
2
3
4
5
6
7
8
void print(tree_node *root,int b){  
   if (root!=NULL)
  { print (root->right,b+1); 
    for (int i=1; i<=b; i++) cout<<"  "; 
    cout<<root->val<<endl; 
    print (root->left,b+1);
    }
}
если кто нибудь знает как это реализовать или поменяй мой print, пож-та скажите.
Заранее спасибо.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Джирайя
3 / 3 / 0
Регистрация: 20.04.2010
Сообщений: 64
22.04.2010, 22:00     Бинарное Дерево(обход дерева) #2
C++
1
2
3
4
5
6
7
8
9
void TreeOut( NodePtr t, int level )
{ int tab = 5;
if (t == NULL) cout <<"Дерево пусто ! \n";
 else
{ if (t->r != NULL) TreeOut(t->r, level+1);   
   cout <<setw(tab*level) <<t->key <<endl;
       if (t->l != NULL) TreeOut(t->l, level+1);           
}
}
lolers
0 / 0 / 0
Регистрация: 16.04.2010
Сообщений: 14
23.04.2010, 12:38  [ТС]     Бинарное Дерево(обход дерева) #3
спасибо, но я кое-что не понял, не могли вы бы объяснить пару моментов:
что за функция setw()?

а то без нее программа работает так же как моя.
спасибо за то ,что очень быстро ответили
mirso
523 / 341 / 17
Регистрация: 05.04.2009
Сообщений: 709
23.04.2010, 13:01     Бинарное Дерево(обход дерева) #4
Цитата Сообщение от lolers Посмотреть сообщение
что за функция setw()?
lolers,
запусти вот это
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <iomanip>
 
int main()//=========================================================
{
    std::cout << std::setw(10) << "setw" << std::endl;
    std::cout << std::setw( 9) << "setw" << std::endl;
    std::cout << std::setw( 5) << "setw" << std::endl;
    std::cout << std::setw( 4) << "setw" << std::endl;
    std::cout                  << "setw" << std::endl;
 
    return 0;
}//==================================================================
lolers
0 / 0 / 0
Регистрация: 16.04.2010
Сообщений: 14
23.04.2010, 19:29  [ТС]     Бинарное Дерево(обход дерева) #5
спасибо..
Джирайя, чем моя программа отличается от вашей?( ну кроме функции setw..)
она выводит тоже самое что и моя((

7
/ \
6 8
/ \ / \
@ @ @ @
надо вывести это дерево лежащее на левом боку, и если левое и правые потомки ==NULL, он выводит "@" на тех местах где нулл)

Добавлено через 6 часов 21 минуту
все спасибо, я сам сделал=)
Yandex
Объявления
23.04.2010, 19:29     Бинарное Дерево(обход дерева)
Ответ Создать тему
Опции темы

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