Технический форум
Вернуться   Технический форум > Программирование > Форум программистов > Помощь студентам


Ответ
 
Опции темы Опции просмотра
Старый 06.12.2015, 21:24   #1 (permalink)
Ана99
Новичок
 
Регистрация: 06.12.2015
Сообщений: 6
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию Найти самое длинное симметpичное слово заданного пpедложения

Найти самое длинное симметpичное слово заданного пpедложения. PascalABC.NET
Ана99 вне форума   Ответить с цитированием

Старый 06.12.2015, 21:24
Helpmaster
Member
 
Аватар для Helpmaster
 
Регистрация: 08.03.2016
Сообщений: 0

Не стоит делать поспешных действий, полистайте аналогичные проблемы

Что из сборки самое слабое?
Самое нужное
iOS 7 - самое неудачное обновление

Старый 06.12.2015, 21:40   #2 (permalink)
Vladimir_S
Специалист
 
Аватар для Vladimir_S
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 26,358
Сказал(а) спасибо: 289
Поблагодарили 507 раз(а) в 165 сообщениях
Репутация: 91953
По умолчанию

Придумайте предложение.
__________________
With Mozilla Firefox - straight to communism!
Vladimir_S вне форума   Ответить с цитированием
Старый 06.12.2015, 22:53   #3 (permalink)
Ана99
Новичок
 
Регистрация: 06.12.2015
Сообщений: 6
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию

Пусть будет такое
q qwq ew qwerrewq aaba
Ана99 вне форума   Ответить с цитированием
Старый 07.12.2015, 10:43   #4 (permalink)
Vladimir_S
Специалист
 
Аватар для Vladimir_S
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 26,358
Сказал(а) спасибо: 289
Поблагодарили 507 раз(а) в 165 сообщениях
Репутация: 91953
По умолчанию

Цитата:
Сообщение от Ана99 Посмотреть сообщение
Пусть будет такое
q qwq ew qwerrewq aaba
Понятно. Пожалуйста.
Единственно, я не пользуюсь ни ABC, ни ABC.Net, написано на Turbo (Free), Вы уж подправьте сами, если что.
Код:
Var
 W:Array[1..100] of String;
 S:String;
 i,j,N,L,Imax,Lmax:integer;

Function Test_symm(D:String):Boolean;
var
 b:boolean;
 Ld,k:integer;
begin
 Ld:=Length(D);
 k:=0;
 b:=true;
 repeat
  Inc(k);
  if D[k]<>D[Ld-k+1] then b:=false;
 until (b=false) or (k=(Ld div 2));
 Test_symm:=b;
end;

Begin
 Writeln('Enter the string');
 Readln(S);
 L:=Length(S);
 Writeln;
 j:=1;
 i:=0;
 Repeat
  W[j]:='';
  repeat
   Inc(i);
  until S[i]<>' ';
  if i<L then
   begin
    while (S[i]<>' ') and (i<=L) do
     begin
      W[j]:=W[j]+S[i];
      Inc(i);
     end;
   end;
  if i<L then Inc(j);
 Until i>=L;
 N:=j;

 Lmax:=0;
 Imax:=0;
 for i:=1 to N do
  if Test_symm(W[i]) and (Length(W[i])>Lmax) then
   begin
    Imax:=i;
    Lmax:=Length(W[i]);
   end;
 if Imax=0 then
  Writeln('String contains no symmetrical words')
 else
  Writeln('Result: '+W[Imax]);
 Readln
End.
И да, еще одно. Я исходил из того, что вводимая строка не содержит знаков препинания, только пробелы. Если нужно с запятыми, точками, тире и т.п. - сообщите, введём, хотя это сильно усложнит код.
__________________
With Mozilla Firefox - straight to communism!
Vladimir_S вне форума   Ответить с цитированием
Старый 07.12.2015, 11:59   #5 (permalink)
Ана99
Новичок
 
Регистрация: 06.12.2015
Сообщений: 6
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию

Мне нужно с циклом while, мы не используем inc
Ана99 вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
Старый 07.12.2015, 12:07   #6 (permalink)
Vladimir_S
Специалист
 
Аватар для Vladimir_S
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 26,358
Сказал(а) спасибо: 289
Поблагодарили 507 раз(а) в 165 сообщениях
Репутация: 91953
По умолчанию

Цитата:
Сообщение от Ана99 Посмотреть сообщение
Мне нужно с циклом while
То есть Repeat..Until - под запретом?
Цитата:
Сообщение от Ана99 Посмотреть сообщение
мы не используем inc
Ну так замените
Inc(k);
на
k:= k + 1;
А вообще подобные тупые ограничения меня мал-мало выбешивают. Но это так, к слову.
__________________
With Mozilla Firefox - straight to communism!
Vladimir_S вне форума   Ответить с цитированием
Старый 07.12.2015, 12:26   #7 (permalink)
Vladimir_S
Специалист
 
Аватар для Vladimir_S
 
Регистрация: 27.08.2008
Адрес: Санкт-Петербург
Сообщений: 26,358
Сказал(а) спасибо: 289
Поблагодарили 507 раз(а) в 165 сообщениях
Репутация: 91953
По умолчанию

Ну ладно, вот:
Код:
Var
 W:Array[1..100] of String;
 S:String;
 i,j,N,L,Imax,Lmax:integer;

Function Test_symm(D:String):Boolean;
var
 b:boolean;
 Ld,k:integer;
begin
 Ld:=Length(D);
 k:=0;
 b:=true;
 while b and (k<=(Ld div 2)) do
  begin
   k:=k+1;
   if D[k]<>D[Ld-k+1] then b:=false;
  end;
 Test_symm:=b;
end;

Begin
 Writeln('Enter the string');
 Readln(S);
 L:=Length(S);
 Writeln;
 j:=1;
 i:=0;
 While i<L do
  begin
   W[j]:='';
   while S[i]=' ' do i:=i+1;
   if i<L then
    begin
     while (S[i]<>' ') and (i<=L) do
      begin
       W[j]:=W[j]+S[i];
       i:=i+1;
      end;
    end;
   if i<L then j:=j+1;
  end;
 N:=j;

 Lmax:=0;
 Imax:=0;
 for i:=1 to N do
  if Test_symm(W[i]) and (Length(W[i])>Lmax) then
   begin
    Imax:=i;
    Lmax:=Length(W[i]);
   end;
 if Imax=0 then
  Writeln('String contains no symmetrical words')
 else
  Writeln('Result: '+W[Imax]);
 Readln
End.
__________________
With Mozilla Firefox - straight to communism!
Vladimir_S вне форума   Ответить с цитированием
Старый 07.12.2015, 12:38   #8 (permalink)
Евгений
Member
 
Аватар для Евгений
 
Регистрация: 31.03.2010
Адрес: Тульская область
Сообщений: 1,167
Сказал(а) спасибо: 9
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 9811
По умолчанию

procedure Proverka(var as1,as2:string);
var j,e,m:byte;
f:boolean;
begin
m:=Length(as1);
e:=0;
f:=true;
for j:=1 to (m div 2) do
if as1[j]=as1[m-j+1]
then e:=e+1
else
begin
f:=false;
as1:='';
Break
end;
if f then
if m>Length(as2)
then
begin
as2:=as1;
as1:='';
end;
end;
var s,s1,s2:string;
i:byte;
begin
Writeln('Vvedite stroku:');
Readln(s);
Writeln;
s1:=''; s2:=''; i:=0;
While i<Length(s) do
begin
i:=i+1;
if i=Length(s) then
begin
s1:=s1+s[i];
if Length(s1)=1
then s1:=''
else Proverka(s1,s2);
end else
if s[i]<>' '
then s1:=s1+s[i]
else
if Length(s1)=1
then s1:=''
else Proverka(s1,s2);
end;
if Length(s2)>0
then Writeln('Samoe dlinnoe sim. slovo: '+s2)
else Writeln('Net simmetricnih slov');
Readln;
end.
Евгений вне форума   Ответить с цитированием
Старый 07.12.2015, 14:59   #9 (permalink)
Ана99
Новичок
 
Регистрация: 06.12.2015
Сообщений: 6
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 10
По умолчанию

Спасибо
Ана99 вне форума   Ответить с цитированием
Ads

Яндекс

Member
 
Регистрация: 31.10.2006
Сообщений: 40200
Записей в дневнике: 0
Сказал(а) спасибо: 0
Поблагодарили 0 раз(а) в 0 сообщениях
Репутация: 55070
Ответ

Опции темы
Опции просмотра

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Выкл.
HTML код Выкл.
Trackbacks are Вкл.
Pingbacks are Вкл.
Refbacks are Выкл.




Часовой пояс GMT +4, время: 09:29.

Powered by vBulletin® Version 6.2.5.
Copyright ©2000 - 2014, Jelsoft Enterprises Ltd.