Модераторы: Poseidon
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Pascal]Построение бинарного дерева 
:(
    Опции темы
Paulskit
Дата 17.4.2008, 00:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 13
Регистрация: 25.11.2007

Репутация: нет
Всего: нет



В общем задача довольно примитивная - построить и вывести на просмотр бинарное дерево со структурой :
      n
     / \
 n-1   n-1

   / \  / \

  ..........

    2      2

   / \     / \

  1   1 1   1

Я думаю глубину дерева можно задать через константу. Спасибо, заранее.

Это сообщение отредактировал(а) Paulskit - 17.4.2008, 00:12
PM MAIL   Вверх
Rodman
Дата 17.4.2008, 11:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


CIO
****


Профиль
Группа: Участник
Сообщений: 6144
Регистрация: 7.5.2006
Где: Ukraine ⇛ Kyiv ci ty

Репутация: 26
Всего: 122



пойдет?
ЗЫ: смотреть в IE!
PM MAIL WWW Skype GTalk YIM MSN   Вверх
Paulskit
Дата 17.4.2008, 18:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 13
Регистрация: 25.11.2007

Репутация: нет
Всего: нет



Не совсем то - у меня проблема сформировать и вывести все как нужно.
PM MAIL   Вверх
volvo877
Дата 18.4.2008, 01:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2073
Регистрация: 15.11.2004

Репутация: 34
Всего: 116



Цитата(Paulskit @  17.4.2008,  17:26 Найти цитируемый пост)
у меня проблема сформировать и вывести все как нужно. 
Вот тут лежит то, что тебе поможет: http://volvo71.narod.ru/faq_folder/bin_tre...m#bintree_graph

(там чуть выше - про формирование дерева, я не думаю, что это является основной проблемой, основная - как раз графическое представление, так?) Учти, чем дерево "глубже", тем хуже отображение... Но все-таки попробуй...
PM MAIL   Вверх
Paulskit
Дата 19.4.2008, 20:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 13
Регистрация: 25.11.2007

Репутация: нет
Всего: нет



Спасибо, написал.

Может кому пригодится - вот мой код:
Код

Program p_tree;
uses Crt;
type ptr=^node;
     node=record
            data :integer;
            left,
            right :ptr;
          end;
var n:integer;
    root :ptr;
    k :integer;

function Step(x:integer;n:word):integer;
var m:integer;
    i:word;
begin
  m:=1;
  for i:=1 to n-1 do m:=m*x;
  Step:=m;
end;

function tree (AmountNode:byte):ptr;
var newnode :ptr;
    LeftNodes,
    RightNOdes :integer;
    str :integer;
begin
  if AmountNode=0 then
     tree:=nil
     else
     begin
       LeftNodes:=AmountNode div 2;
       k:=k-1;
       New (newnode);
       with newnode^ do
       begin
         data:=k;
         left:=Tree(LeftNodes);
       end;
     Tree:=newnode;
     end;
end;

procedure PrintTree (RootTree:ptr;L:byte);
var i :integer;
begin
  if RootTree<>nil then
     with RootTree^ do
     begin

       PrintTree (left, l+1); Writeln;
       for i:=1 to L do write ('           ');
       write (data);
       PrintTree (left,L+1);

     end;
end;

begin 
  Сlrscr;
  writeln ('Display tree ');
  writeln ('Enter number of nodes'); readln (n); k:=n+1;
  n:=Step(2,n);
  root:=Tree(n);
  Clrscr;
  writeln ('Created tree');
  PrintTree (root,0);
  readln
end.

PM MAIL   Вверх
Рыся
Дата 25.6.2010, 22:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 5
Регистрация: 6.1.2010

Репутация: нет
Всего: нет



А можно коментарии к данной программе, пожалуйста, а именно к функциям.

Это сообщение отредактировал(а) Рыся - 25.6.2010, 22:35
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

Если Вам помогли и атмосфера форума Вам понравилась, то заходите к нам чаще! С уважением, Poseidon, Rodman

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Центр помощи | Следующая тема »


 




[ Время генерации скрипта: 0.0647 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.