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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 13.05.2011, 23:34
FAZA FAZA вне форума
Прохожий
 
Регистрация: 05.01.2011
Сообщения: 16
Репутация: 10
По умолчанию Помогите разобраться с двусвязнами списками

вот тест программы, она вводит и выводит числа. числа хранятся в двусвязном списке с фиктивным элементом.
Код:
Type
    List=^element;
    element=record
      num        : integer;
      right,left : List;
    end;
Procedure Creation(var sent : List);
Begin
    new(sent);
    sent^.left:=sent;
    sent^.right:=sent;
end;

Procedure Insertion(p : List; y : integer);
Var
    q : List;
Begin
    new(q);
    q^.num:=y;
    q^.left:=p;
    q^.right:=p^.right;\\ что происходит здесь?
    p^.right^.left:=q;\\ и здесь.
    p^.right:=q;
End;
Var
    i,    k,x : integer;
    sent,p    : List;

Begin
    Reset(input,'input.txt');
    Rewrite(output,'output.txt');
    Creation(sent);

    while not seekeof do begin
        read(x);
        Insertion(sent,x);
    end;
    p:=sent^.left;
    while p<>sent do begin
         Write(p^.num,' ');
         p:=p^.left;
    end;


end
Ответить с цитированием
  #2  
Старый 14.05.2011, 23:48
Аватар для Bargest
Bargest Bargest вне форума
Профессионал
 
Регистрация: 19.10.2010
Адрес: Москва
Сообщения: 2,390
Версия Delphi: XE3/VS12/FASM
Репутация: 14665
По умолчанию

Если вы про комменты "здесь и здесь" - то
создаем новый элемент q, в его правое значение пишем правое текущей позиции (куда вставляем), потом предыдущий элемент для P связываем с q.
были элементы в таком порядке:

p.right p p.left

а стали в таком:

p.right q p p.left

Т.е. СЛЕВА от p.right (вторая интересующая строка) ставится Q, а СПРАВА от Q (первая интересующая строка) ставится p.right.
__________________
jmp $ ; Happy End!
The Cake Is A Lie.

Последний раз редактировалось Bargest, 14.05.2011 в 23:53.
Ответить с цитированием
  #3  
Старый 17.05.2011, 22:22
FAZA FAZA вне форума
Прохожий
 
Регистрация: 05.01.2011
Сообщения: 16
Репутация: 10
По умолчанию

т.е. вот этим действием
Код:
p^.right^.left:=q;
связывается с q предыдущий элемент для p? вот это действие
Код:
q^.left:=p;
для меня более менее понятно. т.е. по адресу поля left списка q записывается адрес списка p. и вот это действие
Код:
q^.right:=p^.right;
я благодаря вам понял помойму правильно. в нем заменяется адрес из поля right списка q, на адрес их поля right списка p. Но вот это действие я не могу понять
Код:
p^.right^.left:=q;
, я запомнил что оно делает, но мне важно понять как это делается. Т.е. по адресу поля right списка р, в этом поле адрес следующего элемента, по нему переходим на след. элемент, там по адресу поля left лежит адрес предыдущего элемента! не могу понять.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

Соглашения

Прочее

 

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