08.06.2010, 15:28
|
#5 (permalink)
|
Member
Регистрация: 29.09.2009
Сообщений: 32
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
|
Цитата:
Сообщение от Vladimir_S
Могу предложить такое решение:
Код:
VAR
f,f1:TEXT;
c:Char;
S,Smax:String;
MaxLeng:WORD;
BEGIN
Assign(f,'D:\Inp_f');
ReSet(f);
Assign(f1,'D:\Out_f');
ReWrite(f1);
Repeat
Repeat
Read(f,c);
If c<>' ' then Write(f1,c);
Until (c=' ') or (EoF(f));
If (NOT EoF(f)) then WriteLn(f1);
Repeat
Read(f,c);
Until (c<>' ') or (EoF(f));
If (NOT EoF(f)) then Write(f1,c);
Until EoF(f);
Close(f);
Close(f1);
MaxLeng:=0;
ReSet(f1);
Repeat
ReadLn(f1,S);
If (Length(S)>MaxLeng) and ((S[2]='e') or (S[2]='E')) then
begin
Smax:=S;
MaxLeng:=Length(S);
end;
Until EoF(f1);
Close(f1);
Erase(f1);
WriteLn('The longest word with second "e" is "'+Smax+'"');
ReadLn;
END.
Здесь применен следующий алгоритм: создается промежуточный файл, в котором КАЖДОЕ слово исходного файла располагается на СВОЕЙ СТРОКЕ. Далее эти строки поочередно считываются из промежуточного файла и из тех, в которых второй буквой является "e" или "E", выбирается наидлиннейшее. ВНИМАНИЕ - ВАЖНО! Во избежание проблем с кодировками символы "e" и "E" считались ЛАТИНСКИМИ! То есть и текст должен быть написан ЛАТИНИЦЕЙ. Впрочем, это можете поправить. В конце программы промежуточный файл уничтожается.
Имена файлов и пути скорректируйте, если надо.
|
Огромное Вам спасибо!
|
|
|