Форум программистов, компьютерный форум, киберфорум
Turbo Pascal
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
 Аватар для SetterZ
0 / 0 / 0
Регистрация: 30.03.2010
Сообщений: 24

Поменять местами в предложении самое длинное и самое короткое слово.

08.05.2010, 09:20. Показов 1951. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста доделать задачу: Поменять местами в предложении самое длинное и самое короткое слово.
Находит самое длинное и самое короткое слово...как поменять их местами и вывести переделанную строку????

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
var i,l,min,max,p1,p2,j:longint;a,b:string;
    t:array[1..60]of string;
    f:array[1..60]of longint;
begin
   write('введите строку : ');readln(a);
   l:=length(a)+1;a[l]:=' ';
   for i:=1 to l do
   if a[i]=' ' then begin
   inc(j);t[j]:=b;
   f[j]:=length(b);b:=''        end  else b:=b+a[i];
    max:=f[1];min:=f[1];p1:=1;p2:=1;
   for i:=1 to j do
    begin
     if max<f[i] then begin max:=f[i];p1:=i; end;
     if min>f[i] then begin min:=f[i];p2:=i; end; end;
   writeln('самое длинное слово: ',t[p1]);
   writeln('самое короткое слово: ',t[p2]);
end.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.05.2010, 09:20
Ответы с готовыми решениями:

В заданном предложении поменять местами самое длинное и самое короткое слова
В заданном предложении поменять местами самое длинное и самое короткое слова. Считать, что слова в тексте отделены друг от друга одним...

В заданном предложении поменять местами самое длинное и самое короткое слова
В заданном предложении поменять местами самое длинное и самое короткое слова. Считать, что слова в тексте отделены друг от друга одним...

Найти самое длинное и самое короткое слово в строке и поменять их местами
Дано предложение. Найти самое длинное и самое короткое слова и поменять их местами. Удалить слова имеющие нечетную длину. Добавлено...

5
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
08.05.2010, 10:43
Лучший ответ Сообщение было отмечено mik-a-el как решение

Решение

Вот посмотрите этот пример.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
uses crt;
var s,s1,s2:string;
    sk,sd:string;
    len,k,d,i,ik,id:byte;
begin
clrscr;
writeln('Введите строку из слов, отделенных пробелами:');
readln(s);
s1:=s+' ';
while pos('  ',s1)>0 do
delete(s1,pos('  ',s1),1);
if s1[1]=' 'then delete(s1,1,1);
sd:='';sk:='';{длинное и короткое слова}
d:=0;k:=255;{их начальная длина}
ik:=1;id:=1;{индекс их начала в строке}
while pos(' ',s1)>0 do
 begin
  len:=pos(' ',s1)-1;
  s2:=copy(s1,1,len);
  if len<k then
   begin
    sk:=s2;{запоминаем кроткое слово}
    k:=len;
    ik:=pos(sk,s);{где оно начинается}
   end;
  if len>d then
   begin
    sd:=s2;{тоже с длинным}
    d:=len;
    id:=pos(sd,s);
   end;
  delete(s1,1,pos(' ',s1));
 end;
writeln('Самое короткое слово ',sk);
writeln('Самое длинное слово ',sd);
if ik<id then{если короткое раньше длинного}
 begin
  insert(sk,s,id);{вставляем короткое перед длинным}
  delete(s,id+k,d);{удаляем длинное}
  insert(sd,s,ik);{вставляем длинное перед коротким где оно было}
  delete(s,ik+d,k);{удаляем короткое}
 end
else{если длинное раньше, тоже, но наоборот}
 begin
  insert(sd,s,ik);
  delete(s,ik+d,k);
  insert(sk,s,id);
  delete(s,id+k,d);
 end;
write(s);
readln
end.
1
 Аватар для SetterZ
0 / 0 / 0
Регистрация: 30.03.2010
Сообщений: 24
08.05.2010, 10:50  [ТС]
Пасибки! Если б не ты я б до ночи решала....
0
Платежеспособный зверь
 Аватар для кот Бегемот
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
08.05.2010, 10:52
PureBasic
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
var 
s,s1,b:string;
    a:array[1..100]of string;
i,k,nmin,nmax:integer;
begin
write('введите строку : ');
readln(s);
s:=' '+s;
for i:=1 to length(s) do
if s[i]=' ' then
inc(k)
else
a[k]:=a[k]+s[i];
nmin:=1;
nmax:=1;
for i:=1 to k do
begin
if length(a[i])>length(a[nmax]) then nmax:=i;
if length(a[i])<length(a[nmin]) then nmin:=i;
end;
   writeln('самое длинное слово: ',a[nmax]);
   writeln('самое короткое слово: ',a[nmin]);
b:=a[nmax];
a[nmax]:=a[nmin];
a[nmin]:=b;
 
for i:=1 to k do
s1:=s1+a[i]+' ';
writeln(s1);
readln;
end.
Добавлено через 34 секунды
Puporev, я слишком долго думаю, но решение короче
0
Почетный модератор
 Аватар для Puporev
64314 / 47610 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
08.05.2010, 10:53
кот Бегемот, С массивами это не есть хорошо, а если нужно сохранить первоначальный вид строки?
0
Платежеспособный зверь
 Аватар для кот Бегемот
8966 / 4389 / 1655
Регистрация: 28.10.2009
Сообщений: 11,647
08.05.2010, 10:55
так она сохранена
исходная -s
новая -s1
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.05.2010, 10:55
Помогаю со студенческими работами здесь

В заданном предложении найти самое короткое и самое длинное слово
Делаю все строго по гайду, но после ввода строки вылетает &quot;exit code = 201&quot;. Пишу в free pascal'е. Эни айдиас? Program lab11; Uses ...

Определить самое длинное и самое короткое слово в предложении
Определить самое длинное и самое короткое слово в предложении, при условии, что каждое слово отделяется от другого пробелом.

В заданном предложении найти самое короткое и самое длинное слова
В заданном предложении найти самое короткое и самое длинное слова. Напечатать исходный текст и найденные слова

Найти самое длинное и самое короткое слово и количество символов в них
Помогите решить задачи на строки.на стандартные операции и функции для строк 1.В предложении разделенным пробелами: а)Найти количество...

Найти во введенном тексте самое короткое и самое длинное слово
задача №3 Найти во введенном тексте самое короткое и самое длинное слово. заранее благодарен за оказанную помощь


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru