Модераторы: volvo877, Snowy, MetalFan
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Pascal] Задача прошу помощи, Дана непустая последовательность слов из 
V
    Опции темы
Dark89
  Дата 20.1.2008, 16:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 1.12.2007

Репутация: нет
Всего: нет



Пожалуйста помогите решитьзадачу не могу никак а надо через неделю сдавать:

Дана непустая последовательность слов из строчных латинских букв;слова разделяются запятыми,за послденим - точка.Среди всех пар a[i] и b[i] ? где a[i]-первая а b[i]- последняя буква i-го слова последовательности, определить наиболее часто встречающуюся пару
PM MAIL   Вверх
Dark89
  Дата 20.1.2008, 18:15 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 1.12.2007

Репутация: нет
Всего: нет



Вот то что сделал но че то никак не работает!

Program ggas;
uses CRT;
 var
   S,S1,a,b:string;
   i,j,MaxK,NmaxK:byte;
   dlinna,dlinna2:integer;
   k: array[1..20] of integer;
begin
   clrscr;
   S:=('abc,wavtobusa,adtokwc,ffs.');
   writeln (S);
   dlinna:=length(s);
   a:=S[1];
    for i:=2 to dlinna do
     begin
      If (S[i]=',') or (S[i]='.') then
      begin
        a:=a+S[i+1];
        b:=b+S[i-1];
       end;
     end;
   dlinna2:=length(a);
     for i:=1 to dlinna2 do
     for j:=i+1 to dlinna2 do
      begin
       if (a[i]=a[j]) and (b[i]=b[j]) then
       k[i]:=k[i]+1;
      end;
MaxK:=k[1];
  NmaxK:=1;
  for i:=2 to dlinna2 do
   if k[i]>MaxK then
   begin
    MaxK:=k[i];
    NmaxK:=i;
   end;
   writeln('Naibolee chasto povtoriaiushiisia para: ',a[NmaxK],b[NmaxK]);
end.
PM MAIL   Вверх
mmvds
Дата 21.1.2008, 09:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 230
Регистрация: 22.12.2007

Репутация: нет
Всего: 6



Код

var str:string;
a,b:array [1..85] of string[1];
c:array [1..85]of integer;
i,j,n,max:integer;
begin
str:='abc,jfajkdfs,asdgjhc,sdfd.';
n:=0;
writeln('Все пары:');
while str<>'' do
begin
  n:=n+1;
  a[n]:=str[1];
  if pos(',',str)<>0 then 
   begin
     b[n]:=str[pos(',',str)-1];
     delete(str,1,pos(',',str));
   end
   else
       begin
         b[n]:=str[pos('.',str)-1];
         delete(str,1,pos('.',str));
       end;
writeln(a[n],' ',b[n]);
end;
for i:=1 to n do
    for j:=1 to n do if (a[i]=a[j]) and (b[i]=b[j]) then c[i]:=c[i]+1;
max:=1;
for i:=1 to n do if c[i]>c[max] then max:=i;
writeln('Наиболее часто встречающаяся пара: ',a[max],' ',b[max]);
readln;
end.

Не факт конечно, что код самый короткий и оптимизированный, но работает smile

85=255/3 (максимальное кол-во пар)

Это сообщение отредактировал(а) mmvds - 21.1.2008, 09:47
PM MAIL ICQ   Вверх
Dark89
  Дата 22.1.2008, 11:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 1.12.2007

Репутация: нет
Всего: нет



Да работает хорошо!!! Спасибо! smile 
PM MAIL   Вверх
THandle
  Дата 22.1.2008, 11:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Хранитель Клуба
Group Icon
Награды: 1



Профиль
Группа: Админ
Сообщений: 3639
Регистрация: 31.7.2007
Где: Moscow, Dubai

Репутация: нет
Всего: 372



Dark89, на будущее: пользуйся кнопкой код. smile 
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Delphi"
THandle
Rrader
volvo877

Запрещается!

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

2. Публиковать ссылки на варез

3. Оффтопить

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь
  • 90% ответов на свои вопросы можно найти в DRKB (Delphi Russian Knowledge Base) - крупнейшем в рунете сборнике материалов по Дельфи

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, THandle, Rrader, volvo877.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Object Pascal: кроссплатформенные технологии | Следующая тема »


 




[ Время генерации скрипта: 0.0734 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.