Помощь - Поиск - Пользователи - Календарь
Полная версия: Помогите разобраться со строками, плиз!
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
what is
Задача-поменять в строке местами самое длинное и короткое слова. Разделители:' ',',','.','!','"','?','/'.
Написала прогу, заработала она, но не так. Удаляет самое короткое слово, а длинное копирует и вставляет в начало строки. Не могу найти ошибку. Помогите. Я знаю, что такая задача есть в FAQ, но найти не смогла.

Program uzas;
const
 limit=[' ',',','.','!','"','?','/'];
var
 s:string;
 i,k,l,imax,imin,b,lmax,lmin:integer;
 s1,s2:string;
begin
 writeln('строка');
 readln(s);
 i:=1;
 k:=0;
 lmin:=length(s);
 while i<=(length(s)) do
 begin
  if not (s[i] in limit) then
  begin
   k:=i;
   s1:=' ';
   while (i<=length(s)) and (not(s[i] in limit)) do
    begin
     s1:=s1+s[i];
     inc(i);
    end;
   if length(s1)<lmin then
   begin
     lmin:=length(s1);
     imin:=k;
   end;
  end;
  inc(i);
 end;
 lmax:=1;
 while i<=length(s) do
 begin
  if not(s[i] in limit) then
  begin
    l:=i;
    s2:=' ';
    while (i<=length(s)) and (not(s[i] in limit)) do
    begin
     s2:=s2+s[i];
     inc(i);
    end;
   if length(s2)>lmax then
   begin
    lmax:=length(s2);
    imax:=l;
   end;
  end
  else
   inc(i);
 end;
  delete(s,imin,lmin);
  delete(s,imax,lmax);
  insert(s2,s,imin);
  insert(s1,s,imax);
  write(s);
  writeln;
end.
wacko.gif wacko.gif wacko.gif
Артемий
Program uzas;
const
 limit=[' ',',','.','!','"','?','/'];
var
 s:string;
 i,k,l,imax,imin,b,lmax,lmin:integer;
 s1,s2:string;
begin
 writeln('строка');
 readln(s);
 i:=1;
 k:=0;
 lmin:=length(s);
 while i<=(length(s)) do
 begin
  if not (s[i] in limit) then
  begin
   k:=i;
   s1:=' ';
   while (i<=length(s)) and (not(s[i] in limit)) do
    begin
     s1:=s1+s[i];
     inc(i);
    end;
   if length(s1)<lmin then
   begin
     lmin:=length(s1);
     imin:=k;
   end;
  end;
  inc(i);
 end;
 lmax:=1;
 while i<=length(s) do
 begin
  if not(s[i] in limit) then
  begin
    l:=i;
    s2:=' ';
    while (i<=length(s)) and (not(s[i] in limit)) do
    begin
     s2:=s2+s[i];
     inc(i);
    end;
   if length(s2)>lmax then
   begin
    lmax:=length(s2);
    imax:=l;
   end;
  end
  else
   inc(i);
 end;
  delete(s,imin,lmin);
  delete(s,imax,lmax);
  insert(s2+' ',s,imin);
  insert(s1+' ',s,imax);
  write(s);
  writeln;
readln
end.

а вот так вроде пашет.
what is
Спасибо за ответ. Еще раз проверю.

вот прогон:
 
строка
че делать? скоро экзамен по проге. ужас!!
ужас  делать? скоро экзамен по проге. ужас!!


все равно не прет...неправильно она слова меняет. В чем причина?
П.С.ужас! я - лузер!!

Помогите несчастному лузеру....
Артемий
А как именно ты хочешь менять самую длинное слово на короткое? blink.gif Местами, или длинное вперед а короткое назад? Она у тебя видимо копирует последнее вперед, а короткое вообще ничего, а первое слово удаляет! wacko.gif
what is
ну я это я вижу.
ну я сначала нашла короткое и длинное слова. затем я удаляю короткое слово и с его начального символа(imin) вставляю длинное. так же с длинным. хотя я вижу, что это вышло только теоритически((
volvo
Ну, давай попробуем вот это:
Program uzas;
const
  limit=[' ',',','.','!','"','?','/'];
var
  s:string;
  i,k,imax,imin,b,lmax,lmin:integer;
  s1,s2, subs:string;

begin
  write('s = '); readln(s);
  { s := '1 123456 12 12345678 1234'; }

  i:=1; k:=0;
  lmin:=length(s); lmax := 1;

  while i<=(length(s)) do begin

    subs := '';
    if not (s[i] in limit) then begin
      k:=i;
      while (i<=length(s)) and (not(s[i] in limit)) do begin
        subs := subs + s[i];
        inc(i);
      end;

      if length(subs) < lmin then begin
        s1 := subs;
        lmin:=length(s1);
        imin:=k;
      end;
      if length(subs) > lmax then begin
        s2 := subs;
        lmax:=length(s2);
        imax:=k;
      end;
    end;
    inc(i);
  end;

  {
    Очень трудноуловимая ошиибка была у тебя: СНАЧАЛА надо удалять слово,
    которое ближе к концу, и СРАЗУ на его место записывать второе - иначе 
    собъешь индексацию ...
  }
  if imin > imax then begin
    delete(s,imin,lmin);
    insert(s2,s,imin);
    delete(s,imax,lmax);
    insert(s1,s,imax);
  end
  else begin
    delete(s,imax,lmax);
    insert(s1,s,imax);
    delete(s,imin,lmin);
    insert(s2,s,imin);
  end;

  write(s);
  writeln;
end.
smile.gif

Кстати, чтобы не делать 2 цикла, я один удалил - это стоило одной дополнительной переменной...
what is
mega_chok.gif все.....

огромное спасибо!!!!
жизнь продолжается...
Это текстовая версия — только основной контент. Для просмотра полной версии этой страницы, пожалуйста, нажмите сюда.