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

Сформировать два списка, отсортировать их и объединить в один, не нарушая порядка

22.03.2016, 18:08. Показов 2898. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток, не могли бы вы помочь написать код к задаче "Сформировать два списка, отсортировать их и объединить в один, не нарушая порядка."? Я был бы признателен вам за помощь.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.03.2016, 18:08
Ответы с готовыми решениями:

Сформировать два списка, отсортировать их и объединить в один, не нарушая порядка
Сформировать два списка, отсортировать их и объединить в один, не нарушая порядка. Заранее спасибо)

Объединить два упорядоченных списка в один, тоже упорядоченный
Program spisoc1; Type spis=^spisoc; spisoc=record inf:integer; link:spis; end; Var begq,endq,p,k:spis; ...

Объединить два упорядоченных по неубыванию списка М1 и М2 в один упорядоченный
Написать программу, содержащую процедуру, которая объединяет два упорядоченных по неубыванию списка М1 и М2 в один упорядоченный по...

2
0 / 0 / 1
Регистрация: 22.03.2016
Сообщений: 4
28.03.2016, 09:19  [ТС]
Лучший ответ Сообщение было отмечено N0D4T1 как решение

Решение

Спасибо, разобрался сам. Может кому пригодится.

Добавлено через 1 минуту
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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
program listsPascal;
 
type
  TData = Integer;
  TPElem = ^TElem;
  {Тип, описывающий элемент списка.}
  TElem = record
    Data: TData;
    PNext: TPElem; {Указатель на следующий элемент.}
  end;
  TList = record
    PFirst: TPElem; 
    PLast: TPElem; 
  end;
 
procedure Init(var emptylst: TList);
begin
  emptylst.PFirst := nil;
end;
 
procedure LFree(var lst: TList);
var
  P, PDel: TPElem;
begin
  P := lst.PFirst;
  while P <> nil do
  begin
    PDel := P; 
    P := P^.PNext; 
    Dispose(PDel);
  end;
  Init(lst);
end;
 
procedure SortBublLink(var lstFirst: TPElem);
var
  tmp, prev, prev1, next, cur: TPElem;
begin
  cur := lstFirst;
  while cur <> nil do
  begin
    tmp := cur^.PNext;
    while tmp <> nil do
    begin
      if tmp^.data < cur^.data then
      begin
        prev := lstFirst;
        prev1 := lstFirst;
        if cur <> lstFirst then
          while prev^.PNext <> cur do prev := prev^.PNext;
        while prev1^.PNext <> tmp do prev1 := prev1^.PNext;
        next := tmp^.PNext;
        if cur^.PNext = tmp then
        begin
          tmp^.PNext := cur;
          cur^.PNext := next;
        end
        else
        begin
          tmp^.PNext := cur^.PNext;
          cur^.PNext := next;
        end;
        if prev1 <> cur then
          prev1^.PNext := cur;
        if cur <> lstFirst then
          prev^.PNext := tmp
        else
          lstFirst := tmp;
        prev1 := tmp;
        tmp := cur;
        cur := prev1;
      end;
      tmp := tmp^.PNext;
    end;
    cur := cur^.PNext;
  end;
end;
 
procedure AddToList(var aL: TList; const aData: TData);
var
  PNew, PCur, PPrev: TPElem;
begin
  New(PNew); 
  PNew^.Data := aData; 
  PNew^.PNext := nil;
  if(al.PFirst = nil) then
  begin
    al.PFirst := PNew;
    al.PLast := PNew;
  end
  else 
  begin
    aL.PLast^.PNext := PNew;
    aL.PLast := PNew;
  end;
end;
 
procedure MergeLists(var lst1: TList; var lst2: TList);
begin
  lst1.PLast^.PNext := lst2.PFirst;  
end;
 
procedure LWriteln(const lst: TList);
var
  P: TPElem;
begin
  P := lst.PFirst; 
  if P <> nil then
    repeat
      if P <> lst.PFirst then
        Write(', ');
      Write(P^.Data); {Распечатываем данные текущего элемента.}
      P := P^.PNext; {Получаем указатель на следующий элемент.}
    until P = nil
  else
    Write('Список пуст.');
  Writeln;
end;
 
var
  L1, L2: TList;
  i, m, n: Integer;
  S: String;
 
begin
  {Начальная инициализация списков.}
  Init(L1);
  Init(L2);
  repeat
    Randomize; {Инициализируем генератор случайных чисел.}
    m := random(5) + 2;
    n := random(5) + 2;
    for i := 1 to M do
    begin
      AddToList(L1, Random(100)); {Случайные целые числа из диапазона: 0..99.}
    end;
    for i := 1 to n do
    begin
      AddToList(L2, Random(100)); {Случайные целые числа из диапазона: 0..99.}
    end;
    Writeln('Заданы списки: ');
    LWriteln(L1);
    LWriteln(L2);
    
    SortBublLink(L1.PFirst);
    SortBublLink(L2.PFirst);
    Writeln('После сортировки: ');
    LWriteln(L1);
    LWriteln(L2);
    
    mergeLists(L1, l2);
    
    Writeln('Результат слияния:');
    LWriteln(L1);
    
    LFree(L1);
    Writeln('Память, выделенная для списков, освобождена.');
    
    Writeln('Повторить - Enter, выход - любой символ + Enter.');
    Readln(S);
  until S <> '';
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.03.2016, 09:19
Помогаю со студенческими работами здесь

Списки. Два упорядоченных по возрастанию списка целых чисел объединить в один
Доброго времени суток, ребята. Нужна помощь в написание программы. Два списка упорядоченных по возрастанию целых чисел объединить в...

Объединить два списка в один и его содержимое тоже выдать на экран.
Доброго времени суток! Заранее извиняюсь если такая тема есть, я её найти не смог. Не могу решить задачу: Создать два связанных...

Объединить два упорядоченных по неубыванию списка в один упорядоченный по неубыванию
Помогите описать процедуру, которая объединяет два упорядоченных по неубыванию списка X1 и X2 в один упорядоченный по неубыванию список.

Два упорядоченных по убыванию списка объединить в один, не нарушив порядка
два упорядоченных по убыванию списка объединить в один не нарушив порядка.

Из исходного списка сформировать два: один с элементами четного порядка, другой с элементами нечетного порядка
Не могли бы написать программу для работы со списками (под unix), которая из одного списка формирует два, один с элементами четного порядка...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Использование 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