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

Найти максимальный элемент непустого списка и переставить его в конец списка

05.12.2015, 04:01. Показов 4237. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток!
Прошу помощи. Задание:
Найти максимальный элемент непустого списка и переставить его в конец списка.

На данный момент программа создает список, добавляет в него элементы, выводит на экран и ищет максимальный элемент в списке, а также добавляет его (максимальный элемент) в конец списка. Всё что нужно - удалить максимальный элемент из этого списка. Никак не могу понять алгоритм удаления из списка, а точнее - его реализацию в Pascal.
С Вас требуется только написание процедуры удаления максимального элемента из списка.
Буду признателен за любую помощь!

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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
program zadanie1;
 
type
  List = ^plist;
  plist = record
    inf: integer;
    next: list;
  end;
 
var
  q, head, last, temp: list;
  n, j, i, s, max: integer;
 
procedure createhead(var head, last: list);
begin
  new(head);
  head^.next := nil;
  last := head;
end;
 
procedure add(var last: list; k: integer);
var
  q: list;
begin
  new(q);
  Q^.inf := k;
  q^.next := nil;
  last^.next := q;
  last := q;
end;
 
procedure print(head: list);
var
  q: list;
begin
  q := head^.next;
  while q <> nil do
  begin
    write(q^.inf, ' -> ');
    q := q^.next;
  end;
end;
 
procedure poisk(head: list; var max: integer);
var
  q: list;
  max1: integer;
begin
  q := head^.next;
  max1 := q^.inf;
  while q <> nil do
  begin
    if max1 < q^.inf then
    begin
      max1 := q^.inf;
      q := q^.next;
    end
    else q := q^.next;
  end;
  write('Максимальный элемент: ', max1);
  max := max1;
end;
 
procedure delete(head: list; max: integer);
var
  q: list;
  max1, l: integer;
begin
  q := head^.next;
  max1 := max;
  l := q^.inf;
  while (q <> nil) do
    if q^.inf = max1 then
    begin
      q := q^.next;
      
    end
    else q := q^.next;
end;
 
begin
  createhead(head, last);
  j := 1;
  write(j, '. ');
  read(n);
  print(head);
  inc(j);
  if n <> 0 then
  begin
    while n <> 0 do
    begin
      add(last, n);
      write(j, '. ');
      read(n);
      inc(j);
    end;
  end
  else
  begin
    writeln('Список пуст!');
    exit;
  end;
  
  print(head);
  writeln;
  poisk(head, max);
  delete(head, max);
  add(last, max);
  writeln;
  print(head);
end.
Добавлено через 53 минуты
Отменяется, разобрался сам:
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
program zadanie1;
 
type
  List = ^plist;
  plist = record
    inf: integer;
    next: list;
  end;
 
var
  q, head, last: list;
  n, j, max: integer;
 
procedure createhead(var head, last: list);
begin
  new(head);
  head^.next := nil;
  last := head;
end;
 
procedure add(var last: list; k: integer);
var
  q: list;
begin
  new(q);
  Q^.inf := k;
  q^.next := nil;
  last^.next := q;
  last := q;
end;
 
procedure print(head: list);
var
  q: list;
begin
  q := head^.next;
  while q <> nil do
  begin
    write(q^.inf, ' -> ');
    q := q^.next;
  end;
end;
 
procedure poisk(head: list; var max: integer);
var
  q: list;
  max1: integer;
begin
  q := head^.next;
  max1 := q^.inf;
  while q <> nil do
  begin
    if max1 < q^.inf then
    begin
      max1 := q^.inf;
      q := q^.next;
    end
    else q := q^.next;
  end;
  write('Максимальный элемент: ', max1);
  max := max1;
end;
 
procedure delete(head: list; max: integer);
var
  temp, q: list;
begin
  q := Head;
  while (q <> nil) and (q^.inf <> max) do
  begin
    temp := q;
    q := q^.Next;
  end;
  temp^.Next := q^.next;
  Dispose(q);
end;
 
begin
  createhead(head, last);
  j := 1;
  write(j, '. ');
  read(n);
  print(head);
  inc(j);
  if n <> 0 then
  begin
    while n <> 0 do
    begin
      add(last, n);
      write(j, '. ');
      read(n);
      inc(j);
    end;
  end
  else
  begin
    writeln('Список пуст!');
    exit;
  end;
  
  print(head);
  writeln;
  poisk(head, max);
  delete(head, max);
  add(last, max);
  writeln;
  print(head);
end.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.12.2015, 04:01
Ответы с готовыми решениями:

Составить программу, которая переносит в конец непустого списка L его первый элемент
Составить программу, которая переносит в конец непустого списка L его первый элемент.

Перенести в конец непустого списка его K-ый элемент
помогите пожалуста с програмой(((: Составить программу, которая переносит в конец не пустого списка его к-й элемент. вот я так...

Перенести в конец непустого списка L1 последний элемент списка L
Не понимаю как осуществить еще 2 процедуры: переносит в конец непустого списка L1 последний элемент списка L; подсчитывает количество...

2
0 / 0 / 0
Регистрация: 27.06.2020
Сообщений: 2
29.06.2020, 15:38
Можешь помочь мне с этим задание не разобрался
0
 Аватар для mr-Crocodile
3053 / 1672 / 657
Регистрация: 19.03.2019
Сообщений: 5,381
29.06.2020, 16:06
DarKVell, код же выложен. Что там непонятного?

хотя, конечно, спорный алгоритм с удалением старого и созданием нового - я бы так не делал, ведь это связанный список - достаточно изменить только ссылки, чтобы элемент переместился в конец списка.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.06.2020, 16:06
Помогаю со студенческими работами здесь

Перенести в конец непустого списка L его первый элемент
Написать процедуру, которая переносит в конец непустого списка L его первый элемент. Язык С

Динамические массивы: перенести в конец непустого списка L его первый элемент
1. Составить программу, которая переносит в конец непустого списка L его первый элемент.

Составить программу, которая переносит в конец непустого списка L его первый элемент
Составить программу, которая переносит в конец непустого списка L его первый элемент

Описать процедуру, которая переносит в конец непустого списка L его первый элемент
2. Описать процедуру, которая переносит в конец непустого списка L его первый элемент. Помогите, пожалуйста, разобраться в чём проблема....

Найти минимальный элемент списка и переставить все его вхождения в начало списка
Допустим есть список , чтоб на выходе получилось


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
YAFU@home — распределённые вычисления для математики. На CPU
Programma_Boinc 20.01.2026
YAFU@home — распределённые вычисления для математики. На CPU YAFU@home — это BOINC-проект, который занимается факторизацией больших чисел и исследованием aliquot-последовательностей. Звучит. . .
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
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
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. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru