
- •1. Введение
- •2. Простейшие операторы языка
- •3. Организация ветвлений
- •4. Логические функции
- •5. Организация циклов
- •Var X,I: integer;
- •Var X,y,I: integer;
- •Операторы итерационных циклов. Их несколько типов. Оператор цикла с предусловием имеет вид
- •С помощью этого оператора гораздо проще решить пример 5-2 (program p5_2n). Оператор цикла с постусловием:
- •6. Массивы
- •Var X,z: array [1..8] of real;
- •Var I,j: integer;
- •Var n,I,j:integer; s,y,sr:real; X: array [1..10,1..5] of real;
- •Var I,j,m,n: integer; X:array [1..10] of integer;
- •Var n,I,j,st,kl,k:integer; a:array [1..10,1..10] of integer;
- •7. Символьные данные
- •Var X:string[1]; d:string; I:integer;
- •Var X,n1,n2,k:integer; st,pr:string;
- •8. Графика
- •Var d,I,m,rx,ry:integer;
- •Var d,m,rx,ry:integer;
- •X,y,xn,xk,ymin,ymax,dx:real; msy,msx:real;
- •9. Подпрограммы
- •10. Записи
- •Var X:vr; y:array [1..5] of vr;
- •11. Файлы
- •Ввод и вывод информации для типизированных и текстовых файлов производится процедурами:
- •X,y:real;
- •X,y:real; I:integer;
- •Im: string[4];
- •I: integer;
- •Im: string[4];
- •I: integer;
П
program
P7_3;
const
s:string='абвxyz123ABC';
{тестовый
пример} begin d:='';
for
i:=1 to length(s) do begin {перебор
символов
в
S}
x:=copy(s,i,1);
{очередной
символ заносится в X}
{если
'а'<=буква<='п',
код уменьшаем на 32}
if
(x>='а')and(x<='п')
then x:=chr(ord(x[1])-32);
{если
'р'<=буква<='я',
код уменьшаем на 80}
if
(x>='р')and(x<='я')
then x:=chr(ord(x[1])-80);
{латинские
преобразуем в заглавные}
if
x<'А'
then
x:=upcase(x[1]);
d:=d+x;
{заполнение
слова D}
end;
write(d);
{результат:
'АБВXYZ123ABC'} end.Var X:string[1]; d:string; I:integer;
Пример 7-3. В строкеSсодержатся русские и латинские символы (заглавные и строчные), цифры и знаки препинания. Преобразовать все символыSв заглавные. Результат занести вD. В программеX– строка размером в один символ, куда заносятся поочередно все символы изSдля преобразования. В результате получимD='абвxyz123ABC'. Преобразование здесь осуществляет оператор видаX:=chr(ord(x[1])-32). Здесь сначала выясняется кодord(x[1]) текущего символа, из него вычитается 32 (т.е. вычисляется код соответствующей заглавной буквы), и, наконец, этот код снова преобразуется в символ.
Пример 7-4. Напечатать целое число X (в диапазоне 0-99) прописью. Такая потребность возникает при печати в финансовых документах “суммы прописью”. Результат поместить в переменную PR. Нам понадобятся три текстовых массива. s1[0..9] для числительных в диапазоне "ноль" – "девять", s2[10..19] для "десять" – "девятнадцать", s3[2..9] для "двадцать" – "девяносто". Начальный и конечный индексы массивов лучше выбирать в соответствии со значениями числительных. Понадобятся вспомогательные переменные. ST – строковое представление X, N1 и N2 – числительные для десятков и единиц в случае, если они формируются отдельно (т.е. для чисел от 20 до 99).
program P7_4; {число прописью}
uses crt;
label m;
Var X,n1,n2,k:integer; st,pr:string;
const
s1: array [0..9] of string=('ноль','один','два', 'три','четыре','пять','шесть','семь','восемь','девять');
s2: array [10..19] of string=('десять','одиннадцать','двенадцать','тринадцать','четырнадцать',
'пятнадцать','шестнадцать','семнадцать','восемнадцать','девятнадцать');
s3: array [2..9] of string=('двадцать','тридцать','сорок','пятьдесят',
'шестьдесят', 'семьдесят', 'восемьдесят', 'девяносто');
begin;
clrscr;
write('введите число X '); readln(x); {ввод преобразуемого числа}
IF x > 99 THEN begin writeln('число слишком велико'); exit; end; {проверка диапазона}
IF x < 10 THEN begin pr:=s1[x]; goto m; end; {число до 9}
IF x < 20 THEN begin pr:=s2[x]; goto m; end; {число от 10 до 19}
{число от 20}
val(copy(st,1,1),n1,k); {десятки}
val(copy(st,2,1),n2,k); {единицы}
pr:=s3[n1]+' '+s1[n2]; {формирование строки прописью}
m: writeln(pr); {вывод результата}
end.
Задания для самостоятельного решения.
7.1.В символьной строкеX(придумайте ее сами) удалить лишние (начальные, конечные и сдвоенные) пробелы.
7.2.В X подсчитать число вхождений слова ‘его’.
7.3.В X поменять порядок символов на обратный.
7.4.В X напечатать самое длинное слово.
7.5.В X подсчитать число вхождений всех встречающихся знаков.
7.6.В X подсчитать число вхождений произвольного символа.
7.7.В X в каждом слове поменять порядок символов на обратный.
7.8.В X расположить слова в порядке увеличения их длины.
7.9. Выяснить, является ли число А полиандром (числом, которое одинаково читается слева-направо и наоборот). Таким число является, например, 23532.
7.10.Есть строкаXдлиной ≤N, предназначенная для вывода. Выровнять при печатиXк правой границе так, чтобы строка занимала всеNпозиций. Выравнивание производить за счет равномерного увеличения числа пробелов между словами.
7.11.Зашифровать строку X, заменив каждый символ, на символ, следующий за данным по алфавиту (буква А заменяется на Б и т.д., буква Я заменяется на А). Расшифровать полученный текст.
7.12.В строкеXимеются открывающиеся и закрывающиеся скобки (включая вложенные). Выяснить, правильно ли они расставлены. Если есть ошибки – сообщить об этом конкретно, включая номер позиции, где она обнаружена.
7.13.СтрокаXсодержит любые русские и латинские символы (как заглавные, так и строчные), цифры и знаки препинания. Преобразовать все символыXв строчные. Результат занести вY.
7.14.Пусть имеется таблица работников бригады со столбцами: Имя, Отработано дней, Зарплата. Отсортировать любым методом таблицу по алфавиту. Для упрощения будем считать, что имена не превышают 8-ми символов, содержат только заглавные буквы и не имеют буквы Ё (эта буква в кодовой таблице русских символов находится не на месте).
7.15.Отсортировать таблицу по алфавиту, где для имен допускаются любые буквы русского алфавита, включая Ё и ё. Сложность здесь заключается как раз в этих буквах. Их коды 240 и 241, т.е. самые большие среди русских букв, в виду чего сравнивать слова придется не целиком, а побуквенно. В случае, если встретилась буква Ё и ё, в программе они должны считаться большими букв Е/е и меньшими Ж/ж.
7.16.Написать программу, которая из заданной даты формирует следующую. Исходная дата задается в форме текстовой строки вида ‘дд.мм.гггг’, например ’06.04.2002’.
7.17.Написать программу, которая от заданной даты (диапазон 1900..2100) находит новую, отстоящую от данной наMмесяцев. Если в новом месяце такой даты нет, берется последний день нового месяца.
7.18.Написать программу, которая от заданной даты (1900..2100), находит новую, отстоящую от данной наXдней.
7.19. Преобразовать число X, отображенное цифрами в число “прописью”:
а). X имеет три разряда в диапазоне 0999.
б). X имеет шесть разрядов в диапазоне 0999 999.
в). X имеет девять разрядов в диапазоне 0999 999 999.
Результатом преобразования, например числа 23 245 012, должно быть выражение “двадцать три млн. двести сорок пять тыс. двенадцать руб.” Основой для решения этих задач является пример 7-4, разобранный выше. Понадобится еще массив для сотен числительных “сто” – “девятьсот”. И отдельный массив для разряда единиц тысяч, поскольку “одна” тысяча, но “один” рубль. При формировании строки следует разбить исходное число на триады (т.е. по три разряда), для которых техника преобразования практически аналогична.