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

Динамические структуры.

23.05.2011, 20:01. Показов 393. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задача: ЕСть список, его элементами является последовательность записей о вагонах(тип и номер). Типов 2 (а и б), нужно составить список в котором будут эти вагоны расставлены с чередованием.
аааббб - абабаб

Алгоритм я составил, но вот с реализацие немного налажал.
Алгорит следующий. Первый вагон сразу в результирующий список.
Когда из первого списка считывается инфа то тип сравнивается с типом в другом списке и если совпадает то вагон записывается в дополнительный список. Если не совпало то дописывается в результирующий список, затем проверяется доп список и если он не пуст то от туда в результирующий список берётся 1 элемент, который затем удаляется из доп списка.

Вот программа, ЕСли влом читать всю прогу то найдите Procedure sort(head:tp; var head1:TP); там вся загвоздка=(
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
Program lab_13;
uses crt;
Type Tinf=integer;
     tinf2=string;
     TP=^Telem;
     Telem=Record
                 tip:tinf2;
                 inf:Tinf;
                 pSled:TP
           End;
Procedure ramki (x1,y1,x2,y2,cf,ct:integer; zag:string);
 begin
window(x1,y1,x2,y2);
textbackground(cf);
clrscr;
textcolor(ct);
writeln(zag);
end;
Procedure Init(Var head:TP);
 
Begin
      head:=NIL
End;
 
Procedure InSpN(infEl:tinf2; infel2:Tinf; Var head:TP);
 
Var pn:TP;
Begin
      New(pn);
      pn^.tip:=infEl;
      pn^.inf:=infEl2;
      pn^.pSled:=head;
      head:=pn
End;
 
Procedure SozdSpN(Var head:TP);
 
Var s:integer;
s1:string;
Begin
      Init(head);
      WriteLn('тип вагона А или В ');
      WriteLn('Признак конца ввода с  ');
      Readln(s1);
      s:=1;
      while s1<>'c' do begin
             InSpN(s1,s,head);
             Readln(s1);
             s:=s+1;
                    end;
      ReadLn
End;
 
Procedure ProsmSp(head:TP);
 
 
Begin
      If head=NIL
      Then Begin
         WriteLn('Список пуст!');
         Write('Нажмите Enter ->');
         ReadLn; Exit;
 
           End;
 
 
      While head<>NIL
      Do Begin Write(head^.tip,'-',head^.inf,' ');
               head:=head^.pSled
         End;
      WriteLn
End;
Procedure OutSpN(Var head:TP);
Var pu:TP;
Begin
  If head<>NIL
  Then Begin
         pu:=head;
         head:=head^.pSled;
         Dispose(pu);
       End;
End;
 
 
Procedure sort(head:tp; var head1:TP);
 
Var pt,pt1,pt2,head2:TP;
Begin
 
      WriteLn('После переобразования:');
      InSpN(head^.tip,head^.inf,head1);
      head:=head^.pSled;
      While head<>NIL
      Do Begin IF head^.tip=head1^.tip then begin
                                                 InSpN(head^.tip,head^.inf,head2);
                                                 head2:=head2^.pSled;
                                            end
                            else begin
                                  InSpN(head^.tip,head^.inf,head1);
                                  head1:=head1^.pSled;
                                  If head2<>NIL then begin
                                                       InSpN(head2^.tip,head2^.inf,head1);
                                                       OutSpN(head);
                                                       head2:=head2^.pSled;
                                                     end;
                                 end;
               head:=head^.pSled;
      End;
 
End;
 
Var
        zag: string;
        y1,x1,x2,y2,cf,ct:byte;
      head,head1,head2:TP;
Begin
       clrscr;
       textbackground(black);
       clrscr;
       x1:=2; y1:=2; x2:=20; y2:=20;
       ct:=18;
       cf:=1;
       zag:='Задание:Создать';
       ramki(x1,y1,x2,y2,cf,ct,zag);
       writeln('список. + элементы');
       writeln('В один список');
       writeln('Остальные в другой.');
       x1:=48; y1:=2; x2:=76; y2:=20;
       zag:='Ответ';
       ramki(x1,y1,x2,y2,cf,ct,zag);
       x1:=24; y1:=2; x2:=44; y2:=20;
       zag:='Создание списка';
       ramki(x1,y1,x2,y2,cf,ct,zag);
       SozdSpN(head);
       Writeln('После создания '); ProsmSp(head);
       x1:=48; y1:=2; x2:=76; y2:=20;
       zag:='Ответ:';
       ramki(x1,y1,x2,y2,cf,ct,zag);
       sort(head,head1);
       ProsmSp(head1);
       readln;
End.
Вот эта строка InSpN(head^.tip,head^.inf,head1); вполне нормально добавляет инфу в список 1 (результурующий), но по какимто причинам абсолютно такая же строчка
InSpN(head^.tip,head^.inf,head2); отказывается делать это со списком 2. ДА и вообще создаётся впечатление что всё что касается списка с head2 не работает...
Где я ошибся?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
23.05.2011, 20:01
Ответы с готовыми решениями:

Динамические структуры данных
type ref = ^integer; var p, q: ref; Пусть p^=2 и q^=3. Что будет выдано на печать в результате...

Динамические структуры данных
Очень прошу помочь с задачкой, бьюсь с ней уже который день... Заранее большое спасибо!! Дано...

Динамические структуры данных
Пусть имеется N городов и задан список пар городов(I, j), между которыми существует прямая дорога. ...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.05.2011, 20:01
Помогаю со студенческими работами здесь

Динамические структуры данных
Списки 2. Написать процедуру или функцию,: а) добавляет в начало списка P новый элемент Q, б)...

Динамические структуры данных
Тема создавалась для размещения здесь решений, связанных с построением структур данных. Стек:...

Ссылки, списки, динамические структуры данных
Написать программу которая печатает текст из первых букв всех слов списка. Help me!

Ссылки, списки, динамические структуры данных
&quot;Написать программу, которая в списке переставляет местами первое и последнее слово&quot; п.с....

Динамические структуры данных. Спроектировать алфавитный указатель.каждый компонент списка содержит слово и номер страницы
Разработать программу с использованием динамических структур данных Спроектировать алфавитный...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru