
- •Введение
- •Глава 1. Основные сведения о работе на персональном компьютере
- •1.1. Конфигурация персонального компьютера
- •Клавиатура
- •Системный блок
- •Монитор
- •1.2. Файловая система ms dos
- •Примеры записи имен файлов
- •1.3. Команды ms dos
- •Системные команды
- •Команды работы с каталогами
- •Команды работы с файлами
- •Команды работы с группой файлов
- •Команды работы с дисками
- •1.4. Инструментальная система nc
- •Основные приемы работы в nc
- •1.5. Контрольные вопросы и задание
- •Тема 1. Конфигурация пк. Клавиатура
- •Тема 2. Файловая система ms dos
- •Тема 3. Команды ms dos
- •Тема 4. Работа в среде nc
- •Глава 2. Работа в интегрированной среде Турбо Паскаль 7.0
- •2.1. Организация вычислений в среде Турбо Паскаль
- •2.2. Главное меню
- •Команда File
- •Команда Edit
- •Команда Search
- •Команда Run
- •Команда Compile
- •2.3. Работа с окнами
- •2.4. Текстовый редактор
- •2.5. Интегрированный отладчик
- •Глава 3. Простейшие конструкции языка Турбо Паскаль
- •3.1. Алфавит языка
- •3.2. Константы и переменные
- •Пример раздела описания переменных
- •3.3. Арифметические выражения
- •Стандартные функции
- •Возведение в степень
- •Примеры программирования арифметических выражений
- •3.4. Контрольные задания
- •1. Составить раздел описания для заданных переменных
- •2. Записать на языке Турбо Паскаль числовые константы
- •3. Записать на языке Турбо Паскаль арифметические выражения
- •4. Записать в виде алгебраической формулы
- •Глава 4. Линейные вычислительные процессы
- •4.1. Оператор присваивания
- •Примеры использования оператора присваивания
- •4.2. Операторы ввода-вывода
- •Операторы ввода исходных данных с клавиатуры
- •Операторы вывода данных на экран
- •4.3. Структура основной программы
- •Общий вид основной программы
- •Пример линейной программы
- •4.4. Контрольные задания
- •1. Записать на языке Турбо Паскаль операторы присваивания
- •Глава 5. Разветвляющиеся вычислительные процессы
- •5.1. Логические выражения
- •Отношения
- •Примеры записи отношений на языке Турбо Паскаль
- •Логические операции
- •Порядок выполнения операций в логических выражениях
- •1. Not. 2. And. 3. Or. 4. Отношения.
- •Примеры записи логических выражений
- •5.2. Условные операторы
- •Короткий условный оператор
- •Полный условный оператор
- •Вложенные структуры условных операторов
- •5.3. Оператор выбора
- •5.4. Контрольные задания
- •1. Записать на языке Турбо Паскаль логические выражения
- •2. Записать на языке Турбо Паскаль логические выражения, принимающие значение true для точек, принадлежащих заштрихованной области (рис. 5.1).
- •3. Начертить на плоскости область, в которой логическое выражение имеет значение true
- •Глава 6. Циклические вычислительные процессы
- •6.1. Операторы цикла с условием
- •Оператор цикла while
- •Оператор цикла repeat…until
- •Основные отличия оператора цикла while от оператора цикла repeat…until
- •6.2. Операторы цикла с параметром
- •Правила использования операторов цикла с параметром
- •6.3. Базовые алгоритмы
- •6.4. Кратные циклы
- •Глава 7. Массивы
- •7.1. Понятие массива
- •7.2. Одномерные массивы
- •Описание одномерного массива
- •Индексные переменные
- •X[I] – индексная переменная (элемент массива).
- •Ввод-вывод одномерных массивов
- •Обработка одномерных массивов
- •7.3. Двухмерные массивы
- •Описание двухмерного массива
- •Ввод-вывод двухмерного массива
- •Обработка матриц
- •Глава 8. Подпрограммы
- •8.1. Структура сложной программы
- •8.2. Процедуры
- •Общий вид описания процедуры
- •Обращение к процедуре
- •Глобальные и локальные переменные
- •Пример программы с процедурой
- •Согласование параметров
- •Механизм замены параметров
- •8.3. Функции
- •Общий вид описания функции
- •Обращение к функции
- •Пример программы с функцией
- •8.4. Параметры-массивы
- •8.5. Примеры программирования задач с использованием подпрограмм
- •Задача 1
- •Задача 2
- •Задача 3
- •Задача 4
- •Глава 9. Текстовые данные
- •9.1. Символьный тип данных
- •Ввод-вывод символьных данных
- •Обработка символьных данных
- •9.2. Строковый тип данных
- •Ввод-вывод строковых данных
- •Обработка строковых данных
- •Пример программирования текстовой задачи
- •9.3. Контрольное задание
- •Глава 10. Записи и файлы данных
- •10.1. Понятие записи
- •10.2. Файлы данных
- •Способы объявления файлов данных
- •Доступ к файлам данных
- •Инициация файла
- •Стандарные функции и процедуры обработки текстовых файлов
- •Пример программирования задачи с использованием файлов данных
- •10.3. Пример решения задачи создания документа
- •4 5 5 Андреева с.В.
- •10.4. Контрольное задание
- •Заключение
- •Библиографический список
- •Приложение 1. Сообщения об ошибках
- •Приложение 2. Таблица альтернативной кодировки символов
Ввод-вывод строковых данных
При вводе строк, как и символов, используется оператор readln. Однако нажатие клавиши [Enter] не является значимым символом. Клавиша [Enter] формирует символ конца строки.
Пример. Организовать ввод ФИО студента.
Var
fam: string;
Begin
writeln(‘Введите фамилию и инициалы студента’);
readln(fam);
На клавиатуре строка набирается без апострофов, например:
Андреева С.В. [Enter]
Одновременно с вводом строки в нулевом байте ячейки для переменной fam устанавливается длина строки, равная 13 символам.
Вывод строк осуществляется с помощью операторов writeln и write. например, оператор
writeln(‘|’, fam:20, ‘|’);
выведет на экран в правую часть поля из 20 позиций строку fam:
| Андреева С.В.|
Обработка строковых данных
К строкам применимы операции отношения и сцепления. К любому символу строки можно обратиться как к элементу одномерного массива, например запись st[2] определяет второй символ в строке st.
Операция отношения
Сравнение двух строк выполняется последовательно слева направо с учетом кодировки символов, например
‘Паскаль’> ‘ПАскаль’,
так как код символа ‘а’ больше кода символа ‘А’.
Операция сцепления
Операция сцепления обозначается символом ‘+’ и служит для объединения двух строк в одну. Например, в результате выполнения операторов:
fam := ‘Андреева С.В.’;
pr := ‘ ’; {7 пробелов}
fam1 := fam + pr;
writeln(‘|’, fam1, ‘|’);
на экран выведется строка:
|Андреева С.В. |
Заметим, что строка вывода занимает поле в 20 позиций, а переменная fam располагается в левой части поля.
Если длина сцепленной строки превысит максимальную длину, заданную в описании, то «лишние» справа символы отбрасываются.
Стандартные функции и процедуры
Большинство действий над строками реализуется с помощью стандартных функций и процедур.
length(st) – функция, возвращающая длину строки st из нулевого байта.
Пример. Определить длину строки fam = Андреева С.В.
length(fam) = 13 (символов).
copy(st, i, n) – функция копирования n символов в подстроку из заданной строки st, начиная с i-й позиции.
Пример. К переменной fam добавить справа 7 пробелов, скопированных из строки pr, заданной константой в разделе Const.
Const
pr := ‘ ’; {20 пробелов}
……………………
fam1 := fam + copy(pr, 1, 7);
writeln(‘|’, fam1, ‘|’);
В результате выполнения данных операторов на экран будет выведена строка:
|Андреева С.В. |
pos(st1, st) – функция поиска подстроки st1 в заданной строке st. Результатом выполнения поиска является номер позиции в строке st, с которой обнаружено первое вхождение подстроки st1.
Пример. В заданной строке st=‘abcd’ найти подстроку ‘bc’.
pos(‘bc’, st) = 2.
delete(st, i, n); – процедура удаления n символов из заданной строки st, начиная с i-й позиции.
Пример. Из заданной строки st=‘abcde’ удалить подстроку ‘cd’.
delete(st, 3, 2);
В результате выполнения процедуры получим: st=‘abe’.
insert(st1, st, i); – процедура вставки подстроки st1 в строку st, начиная с i-й позиции. При вставке оставшиеся в строке st символы сдвигаются вправо.
Пример. В строку st=‘abc’ после символов ‘ab’ вставить символ подчеркивания.
insert(‘_’, st, 3);
В результате выполнения процедуры получим: st=‘ab_c’.
str(x[:w [:d]], st); – процедура преобразования числа x в строку st. Целые числа w, d – необязательные параметры, задающие форматированное преобразование.
Пример. Преобразовать число в строку.
str(pi:6:2, st);
В результате выполнения процедуры получим: st=‘ 3.14’.