Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > [ "Начинающим" ]
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

 
 
Опции темы Поиск в этой теме Опции просмотра
  #2  
Старый 13.05.2012, 12:06
sandysman sandysman вне форума
Новичок
 
Регистрация: 27.03.2012
Сообщения: 60
Репутация: 10
По умолчанию

Эгегей! Может кто-нибудь подскажет хотя бы, правильно я посчитал количество левых вершин правых и общих???
Код:
 
program Trees;

type
   PTernaryNode = ^TTernaryNode;
    TTernaryNode = record
    data: integer;
   cleft : PTernaryNode;
    clright : PTernaryNode;
 end;
Procedure vvodtree (n: integer; var t: PTernaryNode);
begin
if t=nil then
            begin
              new(t);
            with t^ do
             begin
              cleft:=nil;
              clright:=nil;
              data:=n;
             end;
            end
  else
  if n<=t^.data then
                      vvodtree (n, t^.cleft)

                   else
                       vvodtree (n, t^.clright);

end;

procedure vivodtree (t:PTernaryNode);
begin
if t<> nil then
              begin
                    vivodtree (t^.cleft);
                    write (t^.data:3);
                    vivodtree (t^.clright);
              end;

end;

Function balansirovlev (t:PTernaryNode):integer;
begin
if t=nil then
              result:=0
          else result:=1+balansirovlev(t^.cleft);
end;

Function balnsirprav (t:PTernaryNode):integer;
begin
if t=nil then
              result:=0
          else result:=1+ balnsirprav(t^.clright);
end;

Function balnsir (t:PTernaryNode):integer;
begin
if t=nil then
              result:=0
          else result:=1+ balnsir(t^.clright)+balnsir(t^.cleft);
end;

var A,B: PTernaryNode;
chis: integer;
visotalev, visotaprav, ob: integer;
begin
 a:=nil;
 read (chis);
 while chis <> 0 do
  begin
  vvodtree (chis,a);
  read (chis);
  end;
  vivodtree (a);
   visotalev:=balansirovlev(a);
   writeln ();
   writeln(visotalev);
   visotaprav:=balnsirprav(a);
   writeln (visotaprav);
   ob:=balnsir (a);
   writeln (ob);
 end.
.
Ответить с цитированием
 


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 20:56.


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2025