Помощь - Поиск - Пользователи - Календарь
Полная версия: помогите разобраться
Форум «Всё о Паскале» > Pascal, Object Pascal > Задачи
Лейла
задача: Написать программу, которая для каждого слова заданного предложения определяет долю согласных.Определить слово, в котором доля согласных максимальна.
решение:
  
var s:string;
sl:array of string;
k,l,i,j,sogl:integer;
otn:array of real;
max:real;
begin
readln(s); 
k:=0;
repeat
l:=pos(' ',s);
if l<>0 then  
  begin
  k:=k+1;
  setlength(sl,k);
  sl[k-1]:=copy(s,1,l-1);
  delete(s,1,l);
  end
  else
  begin
  k:=k+1;
  setlength(sl,k);

  sl[k-1]:=copy(s,1,length(s));  
  end;
until l=0;

for i:=0 to k-1 do writeln(sl[i]);

setlength(otn,k);

for i:=0 to k-1 do
  begin
  sogl:=0;
  l:=length(sl[i]);
  for j:=1 to l do
  case sl[i,j] of
  'q','w','r','t','p','s','d','f','g','h','j','k','l','z','x','c','v','b','n',
  'm':sogl:=sogl+1;
  end;          
  write(sl[i],' - ');
  otn[i]:=sogl/l;
  if sogl<>0 then writeln(sogl/l:2:3)
              else writeln('sogl net!');
  end;

max:=otn[0];
l:=0;
for i:=1 to k-1 do
  if otn[i]>max then begin max:=otn[i]; l:=i; end;

writeln;
writeln(sl[l]);

readln;
end.

volvo
Ну хорошо, решение есть (что-то оно мне смутно напоминает, но не об этом речь smile.gif ). Что именно в нем непонятно? Сначала разбиваем строку на слова, потом по каждому слову проходим, и ищем число согласных, и отношение к общему кол-ву букв, в результате имеем долю согласных в слове. Из найденных отношений находим максимальное. Что именно непонятно? Где проблема?

P.S. Программа явно не под Турбо Паскаль, это что, Дельфи? Так там есть более интересные способы разбиения строки на слова.
sheka
Цитата(volvo @ 5.06.2009 16:55) *

Так там есть более интересные способы разбиения строки на слова.

какие?
volvo
TStringList и его методы. В одно движение все разбивается... В FPC, кстати, тоже...
Buka
Вот готовая, сама делала))
Всё работает.
program qwe;
uses crt;
type masstr=array [1..10] of string;
type maslength=array [1..10] of byte;
type masdol=array[1..10] of real;
procedure ms(s1:string; var s2:masstr; var l2:maslength; var count:byte);
var i1,i2:byte;
i,l:byte;
begin
l:=length(s1);
i1:=1; i2:=0;
count:=0;
for i:=1 to l do begin
    if (s1[i]= ' ') and (s1[i+1] <> ' ')
    then i1:=i+1;
    if (s1[i] <> ' ') and ((s1[i+1]= ' ') or (i=l)) then begin
    i2:=i; inc(count)
    end;
    if i2 <> 0 then begin
    s2[count]:=copy(s1, i1, i2-i1+1);
    l2[count]:=length(s2[count]);
    i2:=0;
  end;
  end;
end;
procedure doli(s2:masstr; l2:maslength; count:byte; var d:masdol);
var g,i:byte; soglas:byte;    c:char;
begin
for i:=1 to count do begin
soglas:=0;
for g:=1 to l2[i] do begin
 c:=s2[i][g] ;
if  ((c='w') or (c='q') or (c='r') or (c='t') or (c='p')
 or (c='s') or(c='d') or (c='f') or (c='g') or(c='h') or (c='j')
  or (c='k')  or (c='l') or (c='z') or (c='x') or (c='c') or (c='v')
   or (c='b')or (c='n') or (c='m')) then inc(soglas);
d[i]:=soglas/l2[i];
end;
end;
end;
procedure max(d:masdol; count:byte;var  maxd:real);
var i:byte;
begin
maxd:=d[1];
for i:=2 to 10  do begin
if d[1]<d[i]  then maxd:=d[i]
end;
end;
var s:string;
s2:masstr; l2:maslength;  d:masdol;
i,nslov:byte; maxd:real;
begin clrscr;
write(' vvedite predlogenie-> ');
readln(s);
ms(s, s2,l2, nslov);
doli(s2,l2,nslov,d);
max(d,nslov,maxd);
for i:=1 to nslov do   begin
writeln(s2[i], ' ', l2[i] ,' ', d[i]:6:3  );
end;
writeln('max doly soglas ravna  ', maxd:6:3);
readkey
end.



М
Buka, пожалуйста, используй тэги кода и не дублируй мессаджи

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