program Project1;
const
//Множество разделителей слов.
D = [' ', '.', ',', ':', ';', '!', '?', '-', #9, #10, #13];
var
S, StrW : String;
i, Pos1, PosW, Len, LenW, LenWMin : Integer;
IsF : Boolean;
begin
repeat
//Исходный текст.
Writeln('Задайте текст:');
Readln(S);
//Поиск координат первого из самых коротких слов.
Len := Length(S);
LenWMin := 0;
PosW := 0;
Pos1 := 0;
IsF := True;
for i := 1 to Len do begin
//Пропускаем разделители.
if S[i] in D then Continue;
//Отслеживаем начало слова.
if (i = 1) or (S[i - 1] in D) then Pos1 := i;
//Отслеживаем конец слова.
if (i = Len) or (S[i + 1] in D) then begin
//Вычисляем длину слова.
LenW := i - Pos1 + 1;
if IsF then begin
//Самое первое найденное слово, первоначально, принимаем
//как самое короткое.
LenWMin := LenW;
IsF := False;
end else if LenW < LenWMin then begin
//Если это очередное слово короче всех ранее найденных слов, то
//запоминаем его координаты и его длину.
LenWMin := LenW;
PosW := Pos1;
end;
end;
end;
//Показываем результат.
if PosW > 0 then begin
//Искомое слово.
StrW := Copy(S, PosW, LenWMin);
Writeln('Первое из самых коротких слов:');
Writeln(StrW);
end else begin
Writeln('В строке нет слов.');
end;
Writeln('Повторить - Enter. Выход - любой символ + Enter.');
Readln(S);
until S <> '';
end.