Помощь - Поиск - Пользователи - Календарь
Полная версия: Двунаправленный список. Удалить след. элемент после нуля.
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
PFanthem
Двунаправленный список. Программа должна удалить следующий элемент после нуля.
Пример 8 9 10 0 20 7.
Ответ 8 9 10 20 7.
Преподаватель сказал, что проблема в процедуре, якобы не для двунаправленного списка.
program spiski;

type

List = ^TList;
TList = record
data: integer;
next,
prev: List;
end;

var
nach,teck, ends: List;
i, a: integer;

Procedure Del(var first:List);
Var z,x,dx:List;
Begin
z:=first;
While z<>Nil do
if z^.data=0 then
if z=first then begin
first:=first^.next;
Dispose(x);

end
else begin
if z <> nil then
begin
z:=z^.next;
dx^.next^.next:=z^.next;
Dispose(x);
end
else begin {удалить последний}
writeln ('удалить последний');
end;
end;
dx:=z; z:=z^.next;
End;


procedure Print(spis1: List);
begin
if spis1 = nil then
begin
writeln('Список пуст.');
exit;
end
else begin
while spis1 <>nil do
begin
Write(spis1^.data, ' ');
spis1 := spis1^.next
end;
end;
end;


begin
for i := 1 to 11 do
begin
a := random(8) - 5;
if nach = nil then
begin
new(nach);
nach^.next := nil;
nach^.prev := nil;
ends := nach;
end
else
begin
new(ends^.next);
ends^.next^.prev := ends;
ends := ends^.next;
ends^.next := nil;
end;
ends^.data := a;
end;
teck:=nil;
teck:=nach;
Print(nach);
writeln;
Del(teck);
Print(nach);
writeln;
end.

OCTAGRAM
В двунаправленном списке нужно корректировать prev, я не вижу, чтобы prev менялся. Когда элемент последний, нужно корректировать указатель на конец списка, то есть, ends, а он даже не передаётся в процедуру. Для самоконтроля можно написать версию Print, которая будет выводить список в обратном порядке.
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.