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

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

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

> Задачи на списки
Nastas'ka
сообщение 20.10.2005 16:48
Сообщение #1


Гость






Уже месяц не могу решить задачу. а сдать надо было давно, может кто-нидь поможет sad.gif
Текст задачи: В списке L заменить первое вхождение списка L1 на список L2. Решить задачу на однонаправленный список, на двунаправленный и кольцевой.Простым методом и рекурсивным. Помогите хотя бы простым методом на однонаправленный список, дальше может сама разберусь ;)
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов(1 - 7)
volvo
сообщение 20.10.2005 16:58
Сообщение #2


Гость






Nastas'ka, сам список реализован? Или с этим тоже есть проблема?
Если нет реализации самого списка, то идешь сюда:
FAQ: Списки

или сюда:
FAQ: Динамические структуры данных
 К началу страницы 
+ Ответить 
klem4
сообщение 20.10.2005 19:56
Сообщение #3


Perl. Just code it!
******

Группа: Модераторы
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

Репутация: -  44  +


Вот решение, но может быть ошибка, так как сам делал задачу на списки первый раз в жизни ;) Так что кто увидит баг, кричите :yes:

Только я обозначения перепутал, в моей программа ищется первое вхождение L2 в L1 и заменяется на L


uses crt;
type
point = ^item;
item = record
number : integer;
next : point;
end;

var
L, L1, L2, temp : point;

procedure InitItem(var P : point);
var
first : point;
n,num : integer;

begin

write('n='); readln(n);

first := nil;

while(n>0) do begin

new(P);

P^.next := first;

write('Item[',n,']=');
readln(num);

P^.number := num;

first := P;

dec(n);

end;

end;

procedure PrintItem(P : point);
begin
while(p<>nil) do begin
writeln(p^.number);
p := p^.next;
end;
end;

function FindFirstP(a, b : point) : point;
var
res, aBack, bBack : point;
begin

res := nil;

aBack := a;
bBack := b;

while (a<>nil) and (b<>nil) and (res=nil) do begin

res := nil;

while (a<>nil) and (a^.number<>b^.number) do
a := a^.next;
aBack := a;

if (a<>nil) then begin

res := a;

while (a<>nil) and (b<>nil) and (a^.number=b^.number) do begin
a := a^.next;
b := b^.next;
end;

if (b<>nil) then begin
res := nil;
b := bBack;
a := aBack;
a := a^.next;
end
end;
end;

FindFirstP := res;

end;

procedure ReformItem(a, b, p : point);
begin
a := p;
while (a<>nil) and (b<> nil) do begin
a^.number := b^.number;
a := a^.next;
b := b^.next;
end;
end;

Begin

clrscr;

writeln('L1 : ');
InitItem(L1);
writeln;
writeln('L2 : ');
InitItem(L2);
writeln('L3 : ');
InitItem(L);
writeln;

temp := FindFirstP(L1, L2);
if temp = nil then
writeln('No')
else begin
writeln;
ReformItem(L1, L, temp);
PrintItem(L1);
end;

readln;
End.



Сообщение отредактировано: klem4 - 20.10.2005 20:07


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 20.10.2005 22:56
Сообщение #4


Гость






А у меня вот что получилось:
uses crt;
type
point = ^item;
item = record
number : integer;
next : point;
end;

var
L, L1, L2, temp : point;

procedure InitList(var first: point);
var
last: point;

procedure add_item(item: integer);
var p: point;
begin
new(p);
p^.number := item; p^.next := nil;
if first = nil then first := p
else last^.next := p;

last := p
end;

var
n, X: integer;

begin
write('n = '); readln(n);
first := nil; last := nil;

while n > 0 do begin

write('next item = '); readln(X);
add_item(X); dec(n);

end;
end;


procedure PrintList(L: point);
begin

write('list: < ');
while L <> nil do begin

write(L^.number, ' ');
L := L^.next

end;
WriteLn('>');
WriteLn;
end;

function CheckEquals(L, second: point): boolean;
var match: boolean;
begin
match := True;

while (second <> nil) and match do begin
match := (L^.number = second^.number) and
not((L^.next = nil) and (second^.next <> nil));

if match then begin
L := L^.next; second := second^.next;
end;
end;
CheckEquals := match
end;

var
before: point;

function FindFirstPtr(L, sub: point): point;
var found: boolean;
begin
FindFirstPtr := nil;

found := false; before := nil;
while (L <> nil) and not (found) do begin

found := CheckEquals(L, sub);
if not found then begin
before := L; L := L^.next;
end;

end;

if found Then FindFirstPtr := L
end;


procedure ChangeLists(Prev: point;
Var FromL, ToL: point; OldOne: point);
var p: point;
begin
p := FromL;
Prev^.next := ToL;

while OldOne^.next <> nil do begin
OldOne := OldOne^.next;
p := p^.next;
end;

while ToL^.next <> nil do
ToL := ToL^.next;

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

procedure ReformItem(a, b, p : point);
begin
a := p;
while (a<>nil) and (b<> nil) do begin
a^.number := b^.number;
a := a^.next;
b := b^.next;
end;
end;

Begin
clrscr;

writeln('L1 : ');
InitList(L1); PrintList(L1);
writeln('L2 : ');
InitList(L2); PrintList(L2);
writeln('L : ');
InitList(L); PrintList(L);

temp := FindFirstPtr(L, L1);

if temp = nil then writeln('No')
else begin
ChangeLists(before, temp, L2, L1);
PrintList(L);
end;

readln;
End.
 К началу страницы 
+ Ответить 
Nastas'ka
сообщение 21.10.2005 16:29
Сообщение #5


Гость






Спасибо большое-большое, вы мне очень помогли smile.gif .И персональное СПАСИБО volvo и klem4 smile.gif
 К началу страницы 
+ Ответить 
yuivanenko
сообщение 12.05.2010 17:29
Сообщение #6


Новичок
*

Группа: Пользователи
Сообщений: 12
Пол: Мужской

Репутация: -  0  +


Цитата(volvo @ 20.10.2005 22:56) *
А у меня вот что получилось:

Проверяю программу для данных L1- {2;3} L2={0;0;0} L={2;3;2;3} выбивает прогграмму без всяких ответов. Подскажите почему?
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 12.05.2010 17:55
Сообщение #7


Гость






Программа отлаживалась для случая, когда L1 содержится в списке L не с самого начала:
L1- {2;3} L2={0;0;0} L={1;2;3;2;3} - прекрасно отрабатывает... Для указанного случая придется чуть-чуть подкорректировать программу. Хотя сейчас я бы переделал программу совершенно по-другому.
Например, вот так: Прикрепленный файл  sub_list.pas ( 2.45 килобайт ) Кол-во скачиваний: 356


P.S. Кстати, память в программе из 4-го поста не освобождается...
 К началу страницы 
+ Ответить 
yuivanenko
сообщение 13.05.2010 20:44
Сообщение #8


Новичок
*

Группа: Пользователи
Сообщений: 12
Пол: Мужской

Репутация: -  0  +


Цитата(volvo @ 12.05.2010 17:55) *

Программа отлаживалась для случая, когда L1 содержится в списке L не с самого начала:
L1- {2;3} L2={0;0;0} L={1;2;3;2;3} - прекрасно отрабатывает... Для указанного случая придется чуть-чуть подкорректировать программу. Хотя сейчас я бы переделал программу совершенно по-другому.
Например, вот так: Прикрепленный файл  sub_list.pas ( 2.45 килобайт ) Кол-во скачиваний: 356


P.S. Кстати, память в программе из 4-го поста не освобождается...


Огромное спасибо. Сейчас работает со всеми данными

Сообщение отредактировано: yuivanenko - 13.05.2010 21:07
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

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

 



- Текстовая версия 21.07.2025 10:58
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"