Технический форум

Технический форум (http://www.tehnari.ru/)
-   Delphi, Kylix and Pascal (http://www.tehnari.ru/f43/)
-   -   Помогите пожалуйста со строками в Pascal (http://www.tehnari.ru/f43/t51902/)

ma3a 19.05.2011 00:54

Помогите пожалуйста со строками в Pascal
 
Дана символьная строка. Слово - последовательность символов между пробелами, не содержащая пробелы внутри себя. Отредактировать строку, удалив из него слова, которые встречаются в предложении заданное число раз. Результат вывести на экран и в текстовый файл.

Vladimir_S 20.05.2011 17:29

Цитата:

Сообщение от ma3a (Сообщение 523086)
Дана символьная строка. Слово - последовательность символов между пробелами, не содержащая пробелы внутри себя. Отредактировать строку, удалив из него слова, которые встречаются в предложении заданное число раз. Результат вывести на экран и в текстовый файл.

Пожалуйста (имя и расположение файла можете, естественно, поменять):
Код:

VAR
 S:String;
 i,j,Nw,i1,i2,Nt,Nw1:Integer;
 W,W1:Array[1..128] of String;
 times:Array[1..128] of Byte;
 b:Boolean;
 f:text;

BEGIN
 { Ввод строки }
 WriteLn('Enter the string:');
 ReadLn(S);

{ Разбиение строки на слова; слова формируют массив W }
 i:=0;
 Nw:=0;
 Repeat
  Repeat
  Inc(i);
  Until S[i]<>' ';
  i1:=i;
  While (S[i]<>' ') and (i<Length(S)) do
  Inc(i);
  If i=Length(S) then i2:=i else i2:=i-1;
  Inc(Nw);
  W[Nw]:=Copy(S,i1,i2-i1+1);
 Until i=Length(S);

{ Ввод количества повторений }
 Write('How many times? ');
 ReadLn(Nt);

{ Формирование массивов W1 и times; первый содержит перечень слов,
 входящих в строку, БЕЗ ПОВТОРОВ, а второй - количество повторов
каждого из слов в исходной строке
}
 Nw1:=0;
 For i:=1 to Nw do
  begin
  b:=true;
  for j:=1 to i-1 do
    if W[j]=W[i] then b:=false;
  If b then
    begin
    Inc(Nw1);
    W1[Nw1]:=W[i];
    times[Nw1]:=0;
    for j:=i to Nw do
      if W[j]=W1[Nw1] then Inc(times[Nw1]);
    end;
  end;

{ Открытие файла для записи }
 Assign(f,'D:\Out.txt');
 ReWrite(f);
 Writeln(f,S);

{ Вывод на экран и в файл слов исходной строки, не повторяющихся
заданное количество раз
}
 For i:=1 to Nw do
  begin
  b:=true;
  for j:=1 to Nw1 do
    if (W[i]=W1[j]) and (times[j]=Nt) then b:=false;
  If b then
    if i<Nw then
    begin
      Write(W[i]+' ');
      Write(f,W[i]+' ');
    end
    else
    begin
      Write(W[i]);
      Write(f,W[i]);
    end;
  end;

 Writeln;
 Writeln(f);
 Close(f);
 Readln
END.



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

Powered by vBulletin® Version 4.5.3
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.