Форум программистов, компьютерный форум, киберфорум
Pascal ABC
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/25: Рейтинг темы: голосов - 25, средняя оценка - 4.60
1 / 1 / 0
Регистрация: 04.04.2016
Сообщений: 8

Удаление элемента двусвязного списка

04.04.2016, 21:59. Показов 4826. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот такой вот код.
Элемент 5 не удаляется, список выводится таким как и был. Почему?

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
program List1; 
{$APPTYPE CONSOLE} 
type 
PList = ^MyList; 
MyList = record 
Data : integer; 
Next : PList; 
Last : PList; 
end; 
Var L:PList; {указатель на первый элемент} 
Var T:Plist; {указатель на текущий элемент} 
 
//ДОБАВЛЕНИЕ ЭЛЕМЕНТА В НАЧАЛО СПИСКА 
procedure addItemHEAD(list:PList;item:integer); 
var t,n:PList; 
begin 
t:=list; 
while t^.Last<>nil do t:=t^.Last; 
new(n); 
n^.Data:=item; 
n^.Next:=t; 
t^.Last:=n; 
n^.Last:=nil; 
end;
 
//УДАЛЕНИЕ
procedure del( start: PList; item : integer); 
  var n, t : PList; 
begin 
  if start = nil then writeln('Список пуст!') 
  else 
    while (start <> nil) do 
    begin 
      if(start^.data = item) then 
      begin 
      new(n);
      n := start;
      t := n^.next; 
      t^.Last:= n^.last;
      t:=n^.Last;
      t^.next:=n^.next;
      dispose(n); 
      n := nil; 
      end else 
      start := start^.next; 
    end; 
end; 
  
var i:integer; 
begin 
new(L); 
L^.Data:=0; 
L^.Next:=nil; 
L^.Last:=nil; 
T:=L; 
writeln('Исходный список:'); 
for i:=1 to 10 do addItemHEAD(L,i); 
while T^.Last<>nil do T:=T^.Last; 
while T^.Next<>nil do begin write (' ',T^.data); T:=T^.next; end; 
writeln(); 
writeln('Вставка элемента (1) в начало,'); 
addItemHEAD(L,1);
while T^.Last<>nil do T:=T^.Last;  //Возвр указатель в начало
writeln('Удаление элемента  (5) '); 
del(L,5);
while T^.Next<>nil do begin write (' ',T^.data); T:=T^.next; end; 
readln; 
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.04.2016, 21:59
Ответы с готовыми решениями:

Вставка нового элемента в список, удаление элемента из списка, просмотра содержимого списка
очень нужно:tender: 1. Разработать подпрограммы, реализующие основные операции обработки линейного односвязного списка: вставка нового...

Удаление элемента из списка
procedure delite_elem(var ukhead1,ukhead2:next); var pred,x,y,pp:next; Begin x:=ukhead1; y:=ukhead2; pp:=x^.sled; ...

Удаление элемента Х из позиции Р, из списка L
Добрый день, очень прошу помочь с задачкой... 1. Написать программу удаления элемента Х из позиции Р, из списка L. Если в списке нет...

1
44 / 44 / 66
Регистрация: 22.07.2015
Сообщений: 191
05.04.2016, 14:23
После добавления элементов указатель L сместился в конец списка. В качестве параметра функции используй T вместо L.
65 строка
Pascal
1
del(T,5);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.04.2016, 14:23
Помогаю со студенческими работами здесь

Предусмотреть вывод всех данных, поиск элемента двусвязного списка по заданному значению
Help me please!!! В динамической памяти создать двусвязный список из символов латинского алфавита. Предусмотреть вывод всех данных, поиск...

Напишите для двусвязного списка процедуры вставки и удаления перед заданным элементом списка
Напишите для двусвязного списка процедуры вставки и удаления перед заданным элементом списка Помогите, пожалуйста, спасибо заранее!!!

Списки. Удаление элемента списка встречающегося более 1 раза
Здравствуйте помогите пожалуйста с задачей. Задача такова: Написать программу, которая удаляет элемент односвязного списка, который...

Создание списка, печать списка на экран, добавления элемента в начало списка, конец списка
Построить динамическую структуру типа список . Необходимо реализовать следующие процедуры: 1. создание списка. 2. печать списка на...

Представить текст в виде двусвязного списка...
Представить произвольный текст в виде двухсвязного списка из отдельных слов. Задать номера начальной и конечной строк. Этот блок...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru