IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Работа со списками, pascal
сообщение
Сообщение #1


Гость






Необходимо выполнить до 5 января 3 лабы на паскале.
1 Написать рекурсивную процедуру или функцию, определяющую, предшествует ли один заданный символ другому заданному символу.Это нужно добавить в уже выполненную лабу,каторую я предоставлю.
2. Написать программу, позволяющую ввести элементы линейного списка и выполнить задание, указанное в варианте:
Написать процедуру, которая удаляет элемент списка перед каждым вхождением элемента X, если такой есть и отличен от X. Значение X вводить с клавиатуры
3.
Написать программу, позволяющую ввести элементы линейного списка и выполнить задание, указанное в варианте:
С клавиатуры вводятся слова и помещаются в D-список (info:string). Написать проце-дуру, которая меняет местами слова с четными и нечетными номерами (1-е со 2-м, 3-е с 4-м и т.д.).
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов
сообщение
Сообщение #2


Гость






Вот тебе сразу решение задачи №2:
type
plist = ^tlist;
tlist = record
info: integer;
next: plist;
end;

procedure delete_before(first: plist;
X: integer);
var r, p: plist;
begin
p := first;
while p^.next <> nil do begin

if (p^.next^.info = X) and (p^.info <> X) then begin

r := p^.next;
p^ := r^;
dispose( r );
r := nil

end
else p := p^.next;
end;
end;

var
X: integer;
p, first, last: plist;
begin

first := nil; last := nil;

repeat

write('next element: (-999 to exit): '); readln(X);
if X <> -999 then begin

new(p);
p^.next := nil; p^.info := X;
if first = nil then first := p
else last^.next := p;
last := p

end;

until X = -999;
writeln('list:');
p := first;
while p <> nil do begin
write(p^.info:5);
p := p^.next;
end;
writeln;

write('now, enter the X element: '); readln(X);
delete_before(first, X);

writeln('list (after) :');
p := first;
while p <> nil do begin
write(p^.info:5);
p := p^.next;
end;
writeln;
end.
 К началу страницы 
+ Ответить 

Сообщений в этой теме


 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 6.09.2025 15:18
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name