Мы поможем в написании ваших работ!



ЗНАЕТЕ ЛИ ВЫ?

Стандартные (встроенные) процедуры работы со строками

Поиск

 

Delete(St,Poz,N) - удаление из строки St начиная с позиции Poz N символов. Если заказывается удалить больше символов, чем есть в строке, ошибки не возникает (удаляются символы до конца строки). Если Poz за пределами максимальной длины строки, ничего не будет удалено.

Пример:

значения параметров обращение к п/п результат

St='ABCDEFG' Delete(St, 2, 4) St='AFG'

Insert(St1,St2,Poz) - вставка строки St1 в строку St2 начиная с позиции Poz. Пример:

значения параметров обращение к п/п результат

St1='рак';St2='Дон' Insert(St1,St2,2) St2='Дракон' если

максимальная разрешенная длина St2 не меньше 6

 

Str(X,St) - преобразование числового значения Х в символьный вид и запись полученного числа в строку St. После параметра Х можно писать формат преобразования при выводе. Если получающееся число не влезает в строку, правые цифры (символы) числа отбрасываются.

Пример:

значения параметров обращение к п/п результат

X=0.17; St='ерунда' Str(X,St) St=' 1.7000000000000E-01'

если версия Турбо Паскаля ≥6 и максимальная

разрешенная длина St2 не меньше 23

 

Val(St,X,Code) - преобразует символьное изображение числа, записанного в строке St, в двоичное (внутримашинное) представление в переменной X (целого или вещественного типа). Целая переменная Code принимает значение номера неправильного символа, если преобразование невозможно (при этом X примет значение 0). Если при преобразовании получающееся число превышает максимально допустимое значение, процедура заканчивается по ошибке. В случае успешного завершения процедуры, Code принимает значение 0. Следует иметь в виду, что пробелы в строке за изображением числа считаются ошибочными символами и должны быть удалены до обращения к процедуре. Процедура обратная Str.

Пример:

значения параметров обращение к п/п результат

X=0.17; St='-31.4' Val(St,X,K) X=-3.14000000000000E+0001;K=0;

X=0.17; St='-31,4' Val(St,X,K) X=0.0; K=4;

Стандартные (встроенные) функции работы со строками

 

Функции, работающие со строками, в качестве аргумента используют строки, результатом могут быть либо новые строки, либо некоторые числовые характеристики строки - аргумента.

Concat(S1,S2,...Sn) - объединение нескольких строк в одну. Аргументы - имена строк (любое количество), результат - сцепленная строка (при превышении 255 символов, лишние последние символы отбрасываются без сообщения об ошибке). Пример:

Concat('Джентльмены',' у','дачи') вернет строку 'Джентльмены удачи'.

Copy(S,Num,Count) - вырезание подстроки из строки S начиная с символа с номером Num длиной Count символов. Если Num больше длины строки - результат

- строка нулевой длины, если заказанного количества символов в исходной строке не хватает, ошибки не возникает, а результирующая строка просто будет короче. Пример:

Copy('Гидромет',4,3) равно 'ром'.

Length(S) - нахождение текущей длины строки. Аргумент - имя строки, результат - целое число. Пример:

Length('ВТ и программирование') равно 16.

Pos(S,S0) - нахождение места, начиная с которого в строке S0 встречается строка S. Результатом будет целое число - номер позиции в строке S0. Если такого места не найдется, результат равен 0. Пример:

Pos('форма','Информатика') равняется 3.

 

Пример работы со строками.

Написать программу разбиения фразы на отдельные слова и распечатки массива выделенных слов с указанием, сколько раз каждое слово встречается. В качестве фразы использовать начало стихотворения «Не говорите мне – он умер – он живет. Пусть жертвенник разбит, огонь еще пылает, пусть роза сорвана, она еще цветет …».

Алгоритм программы должен учесть следующие моменты:

1) Нужно удалить все знаки препинаний (заменить их пробелами). Для этого, все символы, не попадающие в диапазоны букв, заменим пробелами.

2) Прописные буквы заменить на строчные. Для этого, все символы, попадающие в диапазон прописных букв, заменим соответствующими строчными.

3) Каждое вновь вырезанное слово сравнить с массивом ранее вырезанных слов на предмет совпадения.

В программе будем использовать следующие переменные:

S – исходная строка (150 символов)

Slovo – строка (е более 20 символов) в которую вырезается очередное слово.

Mas – массив строк длинной 20 символов каждая. Количество строк в массиве не более 30. (все выбираем с запасом!)

Kol – массив целых чисел, в котором будет хранится, сколько раз встречается соответствующее слово из массива Mas.

n – количество найденных различных слов.

i,j,m – номера символов в исходной строке (рабочие счетчики).

L – длина вырезаемого слова.

sdvig1,sdvig2 – сдвиги строчных букв от прописных для первой и второй частей алфавита (см. альтернативную кодировку ASCII в конце Практикума)

Pr – признак, что слово повторяется.

 

Program Dictionary;

{ VGI, MIT}

Type

Stroka = string[20];

Var

S:String[150];

Slovo: Stroka;

Mas: array[1..30] of Stroka;

Kol:array[1..30] of integer;

n,i,L,m,j,sdvig1,sdvig2: integer;

Fout:text;

Pr:boolean;

BEGIN

S:=Concat(' Не говорите мне - он умер - он живет.',

' Пусть жертвенник разбит, огонь еще пылает,',

' пусть роза сорвана, она еще цветет...');

{ Вывод исходной строки в выводной файл }

Assign(Fout,'Diction.txt');

ReWrite(Fout);

WriteLn(Fout,'Исходная строка');

WriteLn(Fout,S);

WriteLn(Fout);

{ удаление знаков }

for i:=1 to Length(S) do

if not((S[i]>='А')and(S[i]<='п') or (S[i]>='р')and(S[i]<='я')) then

S[i]:=' '; { если не входит в диапазоны русских букв, заменяем на

пробел }

{ замена строчных на прописные}

sdvig1:= Ord('а') - Ord('А');

sdvig2:= Ord('р') - Ord('Р');

for i:=1 to Length(S) do

if (S[i]<='П') and (S[i]<>' ') then { если прописная от 'А' до 'П'}

S[i]:= Chr(Ord(S[i])+sdvig1)

Else

if (S[i]<='Я') and (S[i]<>' ') then { если прописная от 'Р' до 'Я'}

S[i]:= Chr(Ord(S[i])+sdvig2);

{ Контрольный вывод очищенной строки в выводной файл}

WriteLn(Fout,'Исправленная строка');

WriteLn(Fout,S);

WriteLn(Fout);

{ Основной цикл вырезания слов }

n:=0;

while Length(S)>0 do

Begin

{ поиск начала слова}

j:=1;

while S[j]=' ' do

j:=j+1;

{ поиск конца слова}

i:=j+1;

while S[i]<>' ' do

i:=i+1;

{ копирование слова из исходной строки}

Slovo:= Copy(S,j,i-j);

{ проверка, не встречалось ли слово раньше }

Pr:=FALSE;

for m:=1 to n do

if Slovo = Mas[m] then

Begin

Kol[m]:=Kol[m]+1;

Pr:=TRUE;

{ break;}

end;

if not Pr and (Slovo <> '') then { слово еще не встречалось }

Begin

n:=n+1;

Mas[n]:=Slovo; { записываем его в массив слов }

Kol[n]:=1;

end;

{ удаление символов до следующего слова или до конца строки }

while (i< Length(S)) and (S[i]=' ') do

i:=i+1;

Delete(S,1,i-1);

end; { конец основного цикла }

{ Вывод списка найденных слов }

WriteLn(Fout,'Слова':10,'количество':14);

for m:=1 to n do

WriteLn(Fout,Mas[m]:10, Kol[m]:6);

Close(Fout);

END.

 

Результат работы программы (файл Diction.txt) будет выглядеть так:

 

Исходная строка

Не говорите мне - он умер - он живет. Пусть жертвенник разбит, огонь еще пылает, пусть роза сорвана, она еще цветет...

Исправленная строка

Не говорите мне он умер он живет пусть жертвенник разбит огонь еще пылает пусть роза сорвана она еще цветет

Слова количество

Не 1

Говорите 1

Мне 1

Он 2

Умер 1

Живет 1

Пусть 2

Жертвенник 1

Разбит 1

Огонь 1

Еще 2

Пылает 1

Роза 1

Сорвана 1

Она 1

Цветет 1

 

 

Структуры

 

Вторым, принципиально отличающимся от массива составным типом, является структура.

Структурой называется совокупность разнотипных простых (или составных) данных, объединенных общим именем и расположенных в памяти ЭВМ подряд; обращение к элементам, составляющим структуру, осуществляется с помощью указания, как общего имени структуры, так и внутреннего имени каждого элемента структуры. Имена записываются подряд, разделяясь точкой.

В языке Паскаль этот тип данных носит название "запись". Для его задания используется ключевое слово "record". Примеры описаний переменных типа запись:

TYPE

book = record { задаем описатель записи - book (книга) }

Title: string; { поле названия }

Author: string[20]; { поле для фамилии автора }

Pages: word; { поле для количества страниц -

целого числа без знака }

Price: word; { поле для цены (в рублях) }

end;

VAR

Instruction,Dictionary: book; { заводим две переменные типа book

Library:array[1..30000] of book; { и массив из 30000 структур типа

book }

Имена полей не должны повторяться в пределах записи, но могут совпадать с именами полей в записях других типов или с именами простых переменных. Общий объем памяти для одной структуры равен сумме объемов, занимаемых отдельными полями этой структуры.

Для переменных и констант типа запись как единого целого, возможны операции чтения или записи, присваивания и операции сравнения на равенство

- тождественность (но только для двух переменных, описанных одним общим типом). Каждое отдельное поле переменной типа запись может использоваться в операциях, предусмотренных для данных этого конкретного типа. Таким способом выполняется и заполнение полей операторами присваивания или ввода:

BEGIN

... { присваивание значений полям }

Dictionary.Title:='Толковый словарь по вычислительным системам'; Dictionary.Author:='В.Иллингуорт';

Dictionary.Pages:=560;

Dictionary.Price:=180;

{ вывод названия книги на экран }

Writeln('Название: ',Dictionary.Title);

...

for i:=1 to 3000 do { печать фамилий авторов дорогих книг библиотеки }

if Library[i].Price > 1000 then Writeln(Library[i].Author);

Как видно из примера, обращение к отдельным полям записи может иметь довольно громоздкий вид. Для некоторого удобства предусмотрено использование специального оператора " with ", в котором можно указать общее имя переменной. Например, то же заполнение полей переменной Dictionary можно выполнить так:

With Dictionary do

Begin

Title:='Толковый словарь по вычислительным системам';

Author:='В.Иллингуорт';

Pages:=560;

Price:=180;

end;

Язык Паскаль разрешает использовать в записи в качестве полей массивы и другие записи (описанные раньше). В этом случае внутреннее поле может вызываться с помощью составного имени, состоящего из цепочки имен вложенных структур разделенных точками:

 



Поделиться:


Последнее изменение этой страницы: 2016-08-12; просмотров: 264; Нарушение авторского права страницы; Мы поможем в написании вашей работы!

infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 18.224.57.231 (0.006 с.)