Дана строка, слова разделены одним пробелом, в конце точка - Pascal ABC
Формулировка задачи:
Дана строка, слова разделены одним пробелом, в конце точка. Если последняя буква последнего слова и первая буква слова минимальной длины одинаковы, то поменять их местами. В противном случае удалить слово минимальной длины.
Буду очень благодарна за помощь.
Решение задачи: «Дана строка, слова разделены одним пробелом, в конце точка»
textual
Листинг программы
var s,s1,sp,sm:string;
i,j,im,ip,mn:byte;
begin
writeln('Введите строку из слов, разделенных одним пробелом в конце точка');
readln(s);
//составляем последнее слово
sp:='';
i:=length(s)-1;
while (i>=1)and(s[i]<>' ') do
begin
sp:=s[i]+sp;
i:=i-1;
end;
ip:=i+1; //его начало
//ищем слово минимальной длины
mn:=255;
i:=1;
while i<length(s) do
if (s[i]<>' ')and((i=1)or(s[i-1]=' ')) then
begin
s1:='';
j:=i;
while(j<length(s))and(s[j]<>' ')do
begin
s1:=s1+s[j];
j:=j+1;
end;
if length(s1)<mn then
begin
mn:=length(s1);
im:=i; //его начало
sm:=s1; //само слово
end;
i:=i+length(s1);
end
else i:=i+1;
if sm[1]=sp[1] then //если первые буквы одинаковые
begin
delete(s,ip,length(sp)); //удаляем последнее
insert(sm,s,ip); //на его место вставляем минимальное
delete(s,im,length(sm)); //удаляем минимальное
insert(sp,s,im); //вставляем последнее
end
else delete(s,im,length(sm)); //иначе удаляем минимальное
write(s)
end.
Объяснение кода листинга программы
- Создаются переменные для хранения строки, слов и их длин, а также байтовые переменные для работы с байтами.
- Выводится сообщение для ввода строки.
- Строка разделяется на слова, которые сохраняются в переменной s.
- Создается пустая строка sp для последнего слова.
- Переменная i устанавливается равной длине s минус 1, а переменная j устанавливается равной i.
- Пока i больше или равно 1 и символ s[i] не равен пробелу, выполняется следующая последовательность действий:
- Строка sp увеличивается на текущий символ s[i].
- Переменная i уменьшается на 1.
- Если длина слова s1 меньше min_length, то обновляется min_length, переменная im устанавливается равной i, а переменная sm устанавливается равной s1.
- Если первые буквы слов sm и sp одинаковы, выполняется следующая последовательность действий:
- Строка s удаляется от i до ip, включая сам ip.
- Строка sp вставляется на место строки s в позиции i.
- Переменная im устанавливается равной i.
- Если первые буквы слов sm и sp не одинаковы, выполняется следующая последовательность действий:
- Переменная im устанавливается равной i.
- В конце выводится строка s.