Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лаб раб ч.1 (ЯиМП).doc
Скачиваний:
2
Добавлен:
12.11.2018
Размер:
186.37 Кб
Скачать

26

МИНОБРНАУКИ РОССИИ

Федеральное государственное бюджетное образовательное учреждение

высшего профессионального образования

«Тульский государственный университет»

Кафедра прикладной математики и информатики

Языки и методы программирования

Методические указания по выполнению лабораторных работ

(Часть 1)

для студентов

направления 010500 «Прикладная математика и информатика»

специальности 010501 «Прикладная математика и информатика»

очной формы обучения

Тула 2008

Комплекс работ № 1

Разработка программ

в среде «Borland Pascal 7.0»

 Общие указания

Первый комплекс состоит из 6 лабораторных работ, посвященных изучению основ структурного программирования на языке Pascal, которые необходимо выполнить до первого текущего тестирования по дисциплине «Языки программирования и методы трансляции» (в течение первых 2-х месяцев семестра). Результатом выполнения работ являются файлы с текстами программ и выполняемые файлы программ, представленные преподавателю вместе с правильно оформленным отчетом.

Лабораторные работы можно выполнять в любой среде программирования (Turbo Pascal 5.5, 6.0, 7.0, Borland Pascal 7.0, Borland Delphi 6, 7) и на любой доступной вычислительной технике. Использование объектно-ориентированного языка Pascal необязательно.

 Оформление отчета

Отчет оформляется на стандартных листа формата А4 сразу по всему комплексу работ (работа № 1.1 не оформляется). Для каждой из них необходимо привести:

  1. Название работы.

  2. Постановку задачи.

  3. Описание алгоритма (метода) решения.

  4. Описание баз данных программы.

  5. Текст программы.

  6. Результаты работы программы на 2–3 контрольных примерах.

 Библиографический список

  1. PASCAL 7.0. Практическое программирование: Решение типовых задач.

  2. Turbo Pascal 7. Начальный курс.

  3. Conner B., Niguidula D., Van Dam A., Higuidula D. Object Oriented Programming in Pascal : A Graphical Approach (на английском языке).

  4. Аболрус С. Программирование на Pascal.

  5. Абрамов В.Г., Трифонов Н.П., Трифонова Г.Н. Введение в язык Pascal.

  6. Абрамов С.А., Гнездилова Г.Г., Капустина Е.Н., Селюн М.И. Задачи по программированию.

  7. Алкок Д. Язык Pascal в иллюстрациях.

  8. Аляев Ю., Козлов О. Алгоритмизация и языки программирования Pascal, C++, Visual Basic.

  9. Архангельский А. Object Pascal в Delphi.

  10. Архангельский А. Object Pascal в Delphi 5.

  11. Белецкий Я. Турбо Pascal с графикой для персональных компьютеров.

  12. Боон К. Pascal для всех.

  13. Боровский А. C++ и Pascal в Kylix 3. Разработка интернет-приложений и СУБД.

  14. Бородич Ю.С., Вальвачев А.Н., Кузьмич А.И. Pascal для персональных компьютеров.

  15. Вирт Н. Алгоритмы и структуры данных.

  16. Глинский Я. Turbo Pascal 7.0 и Delphi. Учебное пособие.

  17. Глушаков С.В. Программирование на Turbo Pascal 7.0.

  18. Грогоно П. Программирование на языке Pascal.

  19. Гусева А. Учимся программировать: Pascal 7.0. Задачи и методы их решения.

  20. Епанешников А.М., Епанешников В.А. Программирование в среде Turbo Pascal 7.0.

  21. Зеленяк О. Практикум программирования на Turbo Pascal. Задачи, алгоритмы и решения.

  22. Зуев. Программирование на языке Turbo Pascal 6.0, 7.0.

  23. Йенсен К., Вирт Н. Pascal: руководство для пользователя.

  24. Клатте Р., Кулиш У., Неага М., Рац Д., Улльрих Х. Pascal-XSC. Язык численного программирования. Учебник.

  25. Климов Ю.С., Касаткин А.И., Мороз С.М. Программирование в среде Turbo Pascal 6.0.

  26. Климова Л. Pascal 7.0. Основы практического программирования. Решение типовых задач.

  27. Климова Л. Pascal 7.0. Практическое программирование. Решение типовых задач.

  28. Коффман Э. Turbo Pascal.

  29. Культин Н. Turbo Pascal 7.0 весь процесс создания программы.

  30. Культин Н. Turbo Pascal в задачах и примерах.

  31. Культин Н. Программирование в Turbo Pascal 7.0 и Delphi.

  32. Марченко А.И., Марченко Л.А. Программирование в среде Turbo Pascal 7.0.

  33. Меженный О. Turbo Pascal. Самоучитель.

  34. Меженный О. Turbo Pascal: учитесь программировать.

  35. Моргун А.Н. Решение задач средствами языка Turbo Pascal 7.0: Учебное пособие для средней школы и первых курсов ВУЗов.

  36. Немнюгин С. Turbo Pascal.

  37. Немнюгин С. Turbo Pascal: практикум.

  38. Немнюгин С. Turbo Pascal: Учебник для вузов.

  39. Немнюгин С., Перколаб Л. Изучаем Turbo Pascal.

  40. Перминов О.Н. Программирование на языке Pascal.

  41. Пестриков В.М., Маслобоев А.Н. Turbo Pascal 7.0. Изучаем на примерах.

  42. Пильщиков В.Н. Сборник упражнений по языку Pascal: Учеб. пособие для вузов.

  43. Поляков Д.Б., Круглов И.Ю. Программирование в среде Турбо Pascal (версия 5.5).

  44. Попов В. Turbo Pascal для школьников: учебное пособие.

  45. Прайс Д. Программирование на языке Pascal: практическое руководство.

  46. Рапаков Г., Ржеуцкая С. Turbo Pascal для студентов и школьников.

  47. Рудаков П., Федотов М. Основы языка Pascal.

  48. Рудаков П., Федотов М. Основы языка Pascal. Учебный курс.

  49. РюТен Т., Франкен Г. Турбо Pascal 6.0.

  50. Семашко Г.Л., Салтыков А.И. Программирование на языке Pascal.

  51. Сергиевский М.В., Шаланов А.В. Турбо Pascal 7.0: Язык, среда программирования.

  52. Сухарев Turbo Pascal 7.0 теория и практика программирования.

  53. Тагин М., Ильин В., Архангельский А. Русская справка (HELP) по Delphi 5 и Object Pascal.

  54. Фаронов В.В. Turbo Pascal 7. Начальный курс.

  55. Фаронов В.В. Turbo Pascal 7. Практика программирования.

  56. Фаронов В.В. Turbo Pascal в подлиннике.

  57. Фаронов В.В. Программирование на персональных ЭВМ в среде Турбо Pascal.

  58. Федоренко Ю. Алгоритмы и программы на Turbo Pascal. Учебный курс.

  59. Федоров А. Особенности программирования на Borland Pascal.

  60. Эрбс Х.-Э., Штольц О. Введение в программирование на языке Pascal.

Лабораторная работа № 1.1

РАЗРАБОТКА ПРОСТЕЙШИХ ПРОГРАММ

 Цель работы

Знакомство с интегрированной средой программирования программ Borland Pascal 7.0. Составление и отладка простейших программ с использованием основных операторов языка Pascal.

 Задание

В интегрированной среде Borland Pascal подготовить приведенную ниже программу. Изучить возможности среды по отладке программ.

program Example;

uses Crt;

var i: Integer;

s1, s2: String;

begin

ClrScr;

Writeln('Введите строку символов');

Readln(s1);

s2:='';

for i:=Length(s1) downto 1 do s2:=s2+s1[i];

Writeln('Результирующая строка: ', s2);

end.

 контрольные вопросы

Модель компилятора Borland Pascal 7.0

  1. Какие блоки входят в состав компилятора?

  2. Что представляет собой исходная программа на языке высокого уровня с точки зрения компилятора?

  3. Что такое лексема?

  4. Что такое символ-разделитель?

  5. Какие функции выполняет синтаксический анализатор?

  6. Какие существуют разновидности внутренних кодов компилятора?

  7. Какие функции выполняет генератор кода?

  8. Какова структура профессиональной среды разработки программ Borland Pascal 7.0?

  9. Какие версии компилятора входят в состав пакета Borland Pascal with Objects 7.0?

Набор символов, лексем и разделителей языка

  1. На какие группы можно разделить набор символов языка Turbo Pascal?

  2. Что такое лексема?

  3. Какие категории лексем вам известны?

  4. Допустимо ли использование в качестве пользовательских иденти­фикаторов зарезервированных слов Turbo Pascal?

  5. Что представляет собой идентификатор?

  6. Какая допустимая длина идентификатора?

  7. В чем заключается разница между идентификатором и квалифици­руемым (уточненным) идентификатором?

  8. Какие из идентификаторов могут быть уточненными?

  9. Какие существуют разновидности идентификаторов?

  10. Какие идентификаторы являются стандартными?

  11. Что представляет собой метка?

  12. Какие формы записи чисел используются в языке Turbo Pascal?

  13. Какой символ используется для обозначения шестнадцатеричных чисел?

  14. Что представляет собой строка символов?

  15. Что представляет собой комментарий?

  16. Какие символы используются в качестве разделителей лексем?

  17. Какое количество символов-разделителей допускается между лю­быми двумя лексемами?

Структура программы и ее разделов

  1. Является ли обязательным заголовок программы в языке Turbo Pascal?

  2. В каких случаях используется и где располагается в программе предложение uses?

  3. На какие группы делится множество типов языка Turbo Pascal?

  4. Перечислите стандартные типы языка Turbo Pascal?

  5. Какими свойствами характеризуются порядковые типы?

  6. С помощью каких директив компилятора осуществляется выбор модели генерации кода для чисел вещественных типов?

  7. Какие новые булевские типы введены в языке Turbo Pascal версии 7.0?

  8. Для каких целей были введены новые булевские типы?

  9. Как получить значение кода требуемого символа?

  10. Какая разновидность строк введена в язык Turbo Pascal версии 7.0?

  11. Что представляют собой пользовательские типы?

  12. Какие типы относятся к структурированным?

  13. Каковы стандартные функции, допустимые в константных вы­ражениях?

  14. Что представляют собой типизированные константы?

  15. Поля какого типа не допускаются в типизированных константах типа «запись»?

  16. Что представляет собой типизированная константа процедурно­го типа?

  17. Какие существуют формы описания абсолютных переменных?

  18. Что описывается в предложении export?

  19. Где допустимо использование предложения export?

Операции и выражения языка

  1. Что представляет собой выражение?

  2. Как делятся операции по количеству операндов?

  3. Какими факторами определяется последовательность выполнения операций?

  4. Как подразделяются операции Turbo Pascal по приоритету?

  5. На какие группы можно разделить операции по характеру выпол­няемых действий?

  6. Какое различие между операциями / и div?

  7. Какой тип результата имеют операции отношения?

  8. Какие модели генерации кода поддерживаются в Turbo Pascal при вычислении логических выражений?

  9. К операндам каких типов могут быть применены поразрядные операции?

  10. Какова максимальная длина результирующей строки при выполне­нии строковых операций?

  11. Какие типы операндов допустимы при выполнении операций над множествами?

  12. Какой тип результата имеет операция взятия адреса?

  13. Что может быть использовано в качестве операнда операции @?

Операторы языка

  1. Какие функции выполняют операторы в языке программирования?

  2. Что является разделителем операторов в языке Turbo Pascal?

  3. На какие группы делятся операторы языка Turbo Pascal?

  4. Какие операторы называются простыми?

  5. Как работает оператор присваивания?

  6. Какие действия выполняет оператор процедуры?

  7. Возможна ли передача управления внутрь процедуры (функции) посредством оператора перехода goto и почему?

  8. Почему не рекомендуется использование в программах оператора goto?

  9. Какие операторы языка Turbo Pascal являются структурными?

  10. Что такое составной оператор и какие функции он выполняет?

  11. Как происходит работа условного оператора if?

  12. Может ли встречаться символ ; внутри любого структурного оператора и почему?

  13. Какие особенности существуют при написании вложенных опера­торов if?

  14. Какой оператор позволяет выполнить одно из нескольких дейст­вий в зависимости от результата вычисления выражения?

  15. Какие управляющие конструкции повторения поддерживаются в языке Turbo Pascal?

  16. Как работает оператор цикла while?

  17. В чем заключается различие между операторами repeat и while?

  18. Какие ограничения накладываются на использование оператора for?

  19. Какие существуют отличия и особенности при работе с оператора­ми while, repeat, for?

  20. Для чего предназначен и как выполняется оператор присоединения?

Лабораторная работа № 1.2

РАБОТА СО СТАТИЧЕСКИМИ СТРУКТУРАМИ ДАННЫХ

 Цель работы

Приобретение навыков работы со статическими данными перечисляемого, интервального, строкового типов, типами–множествами и массивами на языке Pascal.

 Задание

Разработать алгоритм, написать и отладить программу решения задачи с использованием операций над множествами.

В программе обязательно использование типов–множеств там, где это наиболее подходит алгоритму. Желательно также использовать данные перечисляемого типа.

 Варианты задания

  1. Ввести два множества чисел. Сформировать и вывести множество чисел из первого множества, которые делятся на заданное число, и из второго множества, не делящихся на это же заданное число.

  2. Ввести две строки символов. Вывести одинаковые символы этих строк.

  3. Ввести строку символов, в которой задана последовательность идентификаторов (синтаксис языка Pascal), отделяемых друг от друга пробелами. Вывести номера ошибочных идентификаторов.

  4. Ввести строку символов, в которой задана последовательность целых чисел (возможно со знаком), разделенных пробелами. Вывести номера некорректно записанных чисел.

  5. Во введенной строке символов подсчитать количество букв (отдельно русского и английского алфавитов), цифр, слов, предложений. (Считать, что слова разделены пробелами, а предложения — точками).

  6. Во введенной строке символов подсчитать количество разделителей (любые скобки, точка, запятая, точка с запятой, пробел).

  7. Во введенной строке символов, содержащей прописные буквы русского алфавита, подсчитать количество различных (без повторений) букв.

  8. Для трех веденных множеств сформировать и вывести множества, являющиеся их объединением и пересечением.

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

  10. Из двух введенных множеств чисел составить третье множество, элементами которого будут совпадающие числа заданного диапазона.

  11. Из трех введенных множеств символов сформировать и вывести четвертое множество символов, входящих ровно в два любых их этих множеств.

  12. Определить, в каком из трех введенных множеств символов больше встречается цифр.

  13. По введенному множеству натуральных чисел заданного диапазона сформировать и вывести множество чисел, делящихся на заданное число.

  14. По введенному множеству натуральных чисел заданного диапазона сформировать и вывести множество нечетных.

  15. По введенному множеству символов сформировать и вывести множество, исключающее все цифры.

  16. По введенному множеству символов сформировать множество символов русского алфавита (строчные и прописные) и вывести его упорядоченным по убыванию.

  17. Подсчитать количество повторений элементов заданного множества символов во введенной строке.

  18. Подсчитать процентное соотношение гласные/согласные во введенной строке, содержащей строчные буквы русского алфавита.

  19. Получить объединение, пересечение, разность и симметрическую разность двух введенных множеств символов.

  20. Сформировать и вывести множество простых чисел из заданного диапазона первых натуральных чисел.

 Контрольные вопросы

Классификация структур данных

  1. На какие группы можно разделить используемые в программиро­вании данные?

  2. В чем состоит основное отличие между данными статической и динамической структуры?

  3. Какие данные относят к данным статической структуры?

  4. Какие данные относят к однородным?

  5. Какие данные относят к неоднородным?

  6. По каким признакам могут быть классифицированы массивы?

  7. Как реализованы строки в Turbo Pascal?

  8. Какие неоднородные структуры данных реализованы в Turbo Pascal?

Управляющие конструкции алгоритмов

  1. С помощью каких двух управляющих конструкций может быть реализован алгоритм произвольной сложности?

  2. В чем состоит отличие между полной и неполной условными кон­струкциями?

  3. Как реализована конструкция выбора?

  4. Чем отличаются циклические конструкции с предусловием и с по­стусловием?

  5. С какими ограничениями реализована конструкция цикла со счет­чиком в Turbo Pascal?

  6. Какое значение может принимать шаг цикла оператора for в Turbo Pascal?

  7. С помощью каких операторов Turbo Pascal может быть смоделиро­ван бесконечный цикл?

  8. Почему не рекомендуется использование конструкции безуслов­ного перехода?

  9. С помощью какой процедуры в Turbo Pascal реализована одно­уровневая конструкция выхода из цикла и в чем состоит ее отличие от многоуровневой конструкции выхода из цикла?

  10. Как работает конструкция продолжения цикла?

  11. Какая процедура Turbo Pascal соответствует конструкции выхода из блока?

Данные статической структуры

  1. С помощью каких процедур осуществляется стандартный ввод в языке Turbo Pascal?

  2. С помощью каких процедур осуществляется стандартный вывод в языке Turbo Pascal?

  3. В чем заключается различие между процедурами Write и Writeln?

  4. Каким образом необходимо выполнять ввод-вывод при работе с переменными структурированных типов и почему?

  5. Значения каких типов могут быть прочитаны процедурами Read и Readln?

  6. Значения каких типов могут быть записаны процедурами Write и Writeln?

  7. Как выполняется процедура Read?

  8. В чем особенности ввода значений строкового типа?

  9. Какое существует различие между процедурами Read и Readln при чтении строковых переменных?

  10. Как происходит выполнение процедуры Writeln?

  11. Какие типы относятся к пользовательским простым типам?

  12. Какие особенности использования переменных перечислимых типов?

  13. Какие действия можно выполнять над переменными перечис­лимых типов?

  14. Допустимо ли использование переменных перечислимых типов в качестве индексов массивов и границ оператора for?

  15. Что представляет собой массив как структура данных?

  16. Какие данные могут выступать в качестве индексов и элементов массива?

  17. Каковы особенности работы со строками?

  18. В чем различие между первым и вторым способом реализации строк?

  19. Какие существуют особенности работы с множествами?

  20. Что такое запись?

  21. Для чего используются уточненные идентификаторы?

  22. Какие преимущества дает использование оператора присоединения?

  23. В каких случаях целесообразно использовать вариантные записи?

  24. Какими правилами определяется совместимость типов в выражениях?

  25. Какими правилами определяется совместимость типов по при­сваиванию?

Лабораторная работа № 1.3

МОДУЛЬНОЕ ПРОГРАММИРОВАНИЕ