Паскаль,работа со списками

Ответить
ge4r
Сообщения: 13
Зарегистрирован: 19 янв 2009, 12:28

добрый день
задача:
из исходного списка путем копирования создать 2 списка,в 1должны быть те слова которые начинаются на заданную комбинацию букв,во 2ом-которые заканчиваюца на эту комбинацию. исходный список и искомая комбинация вводится с клавиатуры

ввод есть:

Код: Выделить всё

type
PList=^TList;
TList=record
 s:string;
 Next,Prev:PList;
end;


var first,Curent,NewI:PList;
s:string;
begin
repeat
readln(s);
new(NewI);
if First=nil then First:=NewI;
NewI^.s:=s;
NewI^.Prev:=Curent;
if Curent<>nil then Curent^.Next:=NewI;
Curent:=NewI;
until s='';
end;




теперь из этого списка нужно вытащить слова начинающиеся и заканчивающиеся на нужную комбинацию,и раскидать по 2ум другим спискам
вот только не пойму,как идти по этому списку,выдергивая из него слово и проверяя его pos'ом...
dr.Jekill
Сообщения: 526
Зарегистрирован: 03 янв 2009, 23:17
Откуда: Voronezh
Контактная информация:

У тебя двусвязный список, т.е. ты можешь двигаться по списку назад и вперед. Последние указатели равны nil. Ты можешь перебирать элементы списка в любую сторону и если встретится элемент, содержательная часть(s:string ;) , которого удовлетворяет условию, ты можешь делать с этим элементом (и его s) всё что хочешь.
Нет религии выше истины
Ответить