С Новым годом! Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 19.12.2017
Сообщений: 22

Подпрограмма: удаление k последних элементов линейного списка

26.02.2018, 21:12. Показов 848. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
реализовать подпрограмму, удаляющую k последних элементов линейного списка. Помогите пожалуйста, на форуме не нашел ответа, прохожу линейные двунаправленные списки, никак не могу понять как с ними работать, если можно то обьясните или подскажите где можно почитать внятную литературу по данной теме

Добавлено через 36 минут
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
69
70
71
72
73
74
75
76
77
78
79
80
program DelK; 
 
type
  TRef = ^TNode;    
  TNode = Record
    left, right: TRef;
    data: integer;
  end;
 
procedure InputList(var list: TRef);
var
  i, n, x: integer;
  q: tref;
begin
  New(list);
  list^.left := nil;
  q := list;
  writeln('kol-vo elementov');
  readln(n);
  for i := 1 to N do
  begin
    write('vvedi ', i, ' element:');
    readln(x);
    New(q^.right);
    q^.right^.left := q;
    q := q^.right;
    q^.data := x;
  end;
  q^.right := nil;
end;
 
 Procedure DelList(q: TRef);
  Begin
   q^.right^.left:=q^.left;
   q^.left^.right:=q^.right;
   Dispose(q);
   end;
   
   Procedure DelK(list: TRef);
  var q:TRef;
  i,n,k,z:integer;
  Begin
  writeln('kol-vo elementov povtorno');
  readln(n);
  writeln('k');
  readln(k);
  i:=1;
  z:=n-k;
   q:=list^.right;
   while q<>nil do
   begin
     if i>z then
     DelList(q);
     q:=list^.right;
     i:=i+1;
   end;
  End;
   
procedure Printlist(caption: string; list: Tref);
begin
  write(caption, ':');
  if list^.right = nil
    then write('spisok pyst')
  else while list^.right <> nil do
    begin
      list := list^.right;
      write(list^.data, ' ');
    end;
  writeln;
end;
 
var
  list: tref;
 
begin
  InputList(list);
  printlist('isxodniy spisok', list);
  DelK(list);
  printlist('polychenniy spisok', list);
end.
Вот что я написал глядя на примеры, но они были для другой задачи, обьясните пожалуйста, что я делаю не так, программа не работает
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.02.2018, 21:12
Ответы с готовыми решениями:

Удаление одинаковых элементов из линейного списка
Здравствуйте, дали задание нужно создать процедуру которая будет удалять элементы у которых значение равно 4. Мои попытки не увенчались...

Удаление n последних элементов из списка
здравствуйте,помогите пожалуйста решить задачу: Удаление n последних элементов из списка

Удаление трех последних элементов списка
Помогите пожалуйста решить задачки на прологе. Создать программу для вычеркивания 3х последних элементов из списка.

1
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,059
27.02.2018, 05:50
Необходимость в двухсвязности списка для демонстрации данного действия — весьма сомнительна.
Ну, если надо…
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
type
  myList = class
    data : Integer;
    pred, next : myList;
    
    constructor (n : Integer; pred_, next_ : myList);
    begin
      data := ReadLnInteger('Введите: ' + n + ' элемент =');
      pred := pred_;
      next := next_;
    end;
    
    procedure print(msg : String := '');
    begin
      Write(msg);
      var Cur := Self;
      while Cur <> nil do
        begin
          Write(' ', Cur.data);
          Cur := Cur.next;
        end;
      WriteLn;
    end;
    
  end;
 
function InputList : myList;
begin
  Result := nil;
  var Last := Result;
  var n := ReadLnInteger('Количество элементов: n =');
  for var i := 1 to n do
    if i = 1 then
      begin
        Result := New myList(i, nil, nil);
        Last := Result;
      end
    else
      begin
        Last.next := New myList(i, Last, nil);
        Last := Last.next;
      end;
end;
  
procedure deleteLast(var List : myList);
begin
  var Cur := List;
  if Cur.next = nil then
    begin
      List := nil;
      Exit;
    end;
  while Cur.next.next <> nil do
    Cur := Cur.next;
  Cur.next := nil;
end;
 
begin
  var List := InputList;
  if List = nil then begin WriteLn('Список пуст.'); Halt; end;
  List.print('Исходный список: ');
  var d := ReadLnInteger('Сколько удалить элементов с конца: d =');
  while (d > 0) and (List <> nil) do begin deleteLast(List); d-=1; end;
  if List = nil then begin WriteLn('Список пуст.'); Halt; end;
  List.print('Новый список: ');
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.02.2018, 05:50
Помогаю со студенческими работами здесь

Удаление первого и двух последних элементов списка
Привет всем!Только начала изучать пролог,вроде получается,но вот с этими задачами не справляюсь!Помогите,пожалуйста,решить!Заранее всем...

Удаление указанного количества последних элементов исходного списка
Добрый день, необходимо из полученного списка удалить n последних элементов. как получить список и переменную n написала, подскажите как...

Удаление указанного количества последних элементов исходного списка.
Здравствуйте, начал разбираться в ПРОЛОГЕ и возникли проблемы! Задача: Создайте предикат, осуществляющий удаление указанного...

Создайте предикат, осуществляющий удаление указанного количества последних элементов исходного списка
Объясните плиз как работает данная программа. Создайте предикат, осуществляющий удаление указанного количества последних элементов...

Функция, возвращающая список состоящий из элементов данного списка + n последних элементов списка
определить функцию принимающую в качестве параметров список символов и число и возвращающую в качестве результата конкатенцию исходного...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru