Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 23.11.2019
Сообщений: 7

Сделать процесс слияния списков в виде процедуры

28.11.2019, 17:14. Показов 408. Ответов 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
69
70
71
72
73
74
program e4;
 
type
  PNode = ^Node;//Создаётся тип "Список"
  Node = record
    data: string;
    next: PNode;
  end;
 
function NewNode(data: string; next: PNode): PNode;//Функция, выделяющая память элементам списка
begin
  New(Result);
  Result^.data := data;
  Result^.next := next;
end;
 
var
  s: string;
  c, c1, c2, i: integer;
  L1, L2, h1, h2: PNode;
 
begin
  Write('Количество элементов в спике  L1: ');
  Readln(c1);  //Заполнение списка
  Writeln('Введите элементы списка через ENTER: ');
  c := 0;
  for i := 1 to c1 do //от 1 до количества элементов в списке
  begin
    Readln(s);
    if c = 0 then begin
      L1 := NewNode(s, L1); //Создание списпка и сохранение указателя на первый элемент
      h1 := L1;
      c := c + 1;
    end
    else begin
      L1^.next := NewNode(s, L1^.next); //заполнение всех последующих элементов
      L1 := L1^.next;
    end;
  end;
  
  Write('Количество элементов в спике L2: '); //Заполнение второго списка
  Readln(c2);     
  Writeln('Введите элементы списка через ENTER: ');
  c := 0;
  for i := 1 to c2 do 
  begin
    Readln(s);
    if c = 0 then begin
      L2 := NewNode(s, L2); //Создаем список и сохраняем указатель на первый элемент
      h2 := L2;
      c := c + 1;
    end
    else begin
      L2^.next := NewNode(s, L2^.next); //заполнение последующих элементов списка
      L2 := L2^.next;
    end;
  end;
  //слияние списков
  L2 := h2;
  while L2 <> nil do 
  begin//
    L1^.next := NewNode(L2^.data, L1^.next);
    L1 := L1^.next;
    L2 := L2^.next;
  end;
  L1 := h1;
  //Вывод полученного списка
  Writeln('Получившийся список: ');
  while L1 <> nil do 
  begin
    writeln(L1^.data);
    L1 := L1^.next;
  end;
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.11.2019, 17:14
Ответы с готовыми решениями:

Сортировка посредством слияния списков
Помогите пожалуйста написать алгоритм сортировки посредством слияния списков

Решить задачу слияния 2 списков по какому-либо условию
4.Решить задачу слияния 2 списков по какому-либо условию. Например, к концу очереди добавить список, добавить список к началу стэка или из...

Как из двух списков сделать один список кортежей/списков
Доброго времени суток! Буду очень благодарен, если поможете из двух списков, к примеру a и b, сделать список c, который содержит пары...

5
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
28.11.2019, 17:20
У вас не происходит слияния.
Вы создаёте новые элементы списка.
В то время, как я понимаю, именно сами элементы второго списка должны попадать в слитый первый список!

После выполнения вашей программы, попробуйте вывести список h2. Вы увидите второй список неизменным!
0
0 / 0 / 0
Регистрация: 23.11.2019
Сообщений: 7
28.11.2019, 17:20  [ТС]
по сути да, но задача написать для этого процедуру всё ещё актуальна
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
28.11.2019, 17:22
Так „по сути?“ или нет, мы не имеем ни малейшего понятия!
Ибо не знаем полного исходного задания…
0
0 / 0 / 0
Регистрация: 23.11.2019
Сообщений: 7
28.11.2019, 17:25  [ТС]
если конкретно, то требуется сделать процесс переноса элементов второго списка в конец первого в виде процедуры!
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
28.11.2019, 17:58
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
type
  PNode = ^Node;//Создаётся тип "Список"
  Node = record
    data: string;
    next: PNode;
  end;
 
function NewNode(data: string): PNode;//Функция, выделяющая память элементам списка
begin
  New(Result);
  Result^.data := data;
  Result^.next := nil;
end;
 
procedure слияниеСписков(var h1, h2 : PNode);
begin
  if h1 = nil then
    h1 := h2
  else
    begin
      var last := h1;
      while last^.next <> nil do last := last^.next;
      last^.next := h2;
    end;
  h2 := nil;
end;
 
var
  L, h1, h2: PNode;
 
begin
  var c := ReadLnInteger('Количество элементов в спике  L1:');
  if c > 0 then
    begin
      Writeln('Введите элементы списка через ENTER: ');
      h1 := NewNode(ReadLnString);
      L := h1;
      loop c-1 do
        begin
          L^.next := NewNode(ReadLnString);
          L := L^.next;
        end;
    end;
  
  c := ReadLnInteger('Количество элементов в спике  L2:');
  if c > 0 then
    begin
      Writeln('Введите элементы списка через ENTER: ');
      h2 := NewNode(ReadLnString);
      L := h2;
      loop c-1 do
        begin
          L^.next := NewNode(ReadLnString);
          L := L^.next;
        end;
    end;
  
  слияниеСписков(h1, h2);
 
  //Вывод полученного списка
  Writeln('Получившийся список: ');
  L := h1;
  while L <> nil do 
    begin
      L^.data.Print;
      L := L^.next;
    end;
  WriteLn;
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.11.2019, 17:58
Помогаю со студенческими работами здесь

Оформить отсортированный массив в виде процедуры, а сумму отрицательных чисел - в виде функции
Помогите пожалуйста оформить отсортированный массив, в виде процедуры, а сумму отрицательных чисел оформить в виде функции. PROGRAM...

Как сделать так что бы батник мониторил процесс и если процесс перезепустился то запуск или перезапуск другой программы
помогите , как сделать так что бы батник мониторил процесс и если процесс перезепустился то запуск или перезапуск другой программыпро...

Вычисления суммы ряда оформить в виде функций, используемые функции и процедуры оформить в виде модуля
Напишите программу полностью, очень прошу! Вычисления оформить в виде функции, используемые функции и процедуры оформить в виде модуля ...

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

Узнать результат процедуры инжекта в процесс
Есть процедура: procedure RemoteLoadLibrary(PID:Cardinal; name:Pchar); var h:Cardinal; NameLength: Cardinal; dllNameInProc...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru