Дана строка, слова разделены одним пробелом, в конце точка - 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.

Объяснение кода листинга программы

  1. Создаются переменные для хранения строки, слов и их длин, а также байтовые переменные для работы с байтами.
  2. Выводится сообщение для ввода строки.
  3. Строка разделяется на слова, которые сохраняются в переменной s.
  4. Создается пустая строка sp для последнего слова.
  5. Переменная i устанавливается равной длине s минус 1, а переменная j устанавливается равной i.
  6. Пока i больше или равно 1 и символ s[i] не равен пробелу, выполняется следующая последовательность действий:
    • Строка sp увеличивается на текущий символ s[i].
    • Переменная i уменьшается на 1.
  7. Если длина слова s1 меньше min_length, то обновляется min_length, переменная im устанавливается равной i, а переменная sm устанавливается равной s1.
  8. Если первые буквы слов sm и sp одинаковы, выполняется следующая последовательность действий:
    • Строка s удаляется от i до ip, включая сам ip.
    • Строка sp вставляется на место строки s в позиции i.
    • Переменная im устанавливается равной i.
  9. Если первые буквы слов sm и sp не одинаковы, выполняется следующая последовательность действий:
    • Переменная im устанавливается равной i.
  10. В конце выводится строка s.

Оцени полезность:

14   голосов , оценка 3.929 из 5
Похожие ответы