Студопедия

Главная страница Случайная страница

КАТЕГОРИИ:

АвтомобилиАстрономияБиологияГеографияДом и садДругие языкиДругоеИнформатикаИсторияКультураЛитератураЛогикаМатематикаМедицинаМеталлургияМеханикаОбразованиеОхрана трудаПедагогикаПолитикаПравоПсихологияРелигияРиторикаСоциологияСпортСтроительствоТехнологияТуризмФизикаФилософияФинансыХимияЧерчениеЭкологияЭкономикаЭлектроника






Пример выполнения задания. Создать список целочисленных элементов






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

// Лабораторная работа 1.

// Реализация списков с помощью динамических переменных.

// Выполнил Сергеев Андрей, группа 999.

// Формирование двух списков из исходного списка.

// Исходные данные – элементы основного списка – в файле LW1Dat.txt

// Результаты работы помещаются в файл LW1Res.txt

program LW1;

{$APPTYPE CONSOLE}

uses SysUtils;

type

tValue=Integer; // тип содержательной части элемента списка – целый

pItem=^tItem; // тип указателя на элемент списка

tItem=record // тип элемента списка

Value: tValue; // содержательная часть элемента списка

Next: pItem; // указатель на следующий элемент списка

end; // record tItem

procedure Create(var List: pItem); // Создание пустого списка List

begin

List: =nil;

end; //procedure Create

procedure InsertFirst(var List: pItem; v: tValue);

// Включение элемента со значением v в начало списка List

var NewItem: pItem; // указатель на новый элемент списка

begin

New(NewItem); // выделение памяти под новый элемент списка

NewItem^.Value: =v; // запись v в поле Value нового элемента

NewItem^.Next: =List; // новый элемент ссылается на первый

List: =NewItem; // новый элемент становится первым

end; // procedure InsertFirst

procedure InsertLast(var List: pItem; v: tValue);

// Включение элемента со значением v в конец списка List

var NewItem, LastItem: pItem; // указатели на новый и последний элементы

begin

New(NewItem); // выделение памяти под новый элемент списка

NewItem^.Value: =v; // запись значения v в поле Value нового элемента

NewItem^.Next: =nil; // новый элемент становится последним в списке

if List=nil // если список пуст,

then List: =NewItem // то новый элемент становится первым в списке

else begin // список не пуст – поиск последнего элемента:

LastItem: =List; // устанавливаем LastItem на начало списка,

while LastItem^.Next< > nil do begin // пока не достигнут конец списка,

LastItem: =LastItem^.Next; // сдвигаем LastItem на следующий элемент

end;

LastItem^.Next: =NewItem; // новый элемент следует за последним

end;

end; // procedure InsertLast

procedure WriteList(var f: Text; List: pItem); // Вывод в файл f элементов списка List

var Item: pItem; // указатель на элемент списка

begin

Item: =List; // устанавливаем Item на начало списка

while Item< > nil do begin // пока не достигнут конец списка:

Write(f, Item^.Value: 5); Item: =Item^.Next; // вывод элемента и сдвиг Item

end;

Writeln(f);

end; // procedure WriteList

function Size(List: pItem): Word;

// Возвращение числа элементов списка

var Item: pItem; // указатель на элемент списка

Begin

Item: =List; // устанавливаем Item на начало списка

Result: =0; // обнуляем счетчик числа элементов

while Item< > nil do begin // пока не достигнут конец списка:

Item: =Item^.Next; Inc(Result); // сдвигаем Item и увеличиваем счетчик

end; // while

end;

procedure Clear(var List: pItem);

// Удаление элементов списка

var Item: pItem; // указатель на удаляемый элемент списка

begin

while List< > nil do begin // пока список не пуст:

Item: =List; // устанавливаем Item на начало списка,

List: =List^.Next; // передвигаем начало списка на следующий элемент

Dispose(Item); // и удаляем элемент

end; // while

end; //procedure Clear

procedure FormLists(L: pItem; var L1, L2: pItem);

// Формирование списков L1 и L2 из списка L по правилу:

// отрицательные нечетные – в L1, положительные четные – в L2

var Item: pItem; // указатель на текущий элемент списка

begin

Item: =L; // устанавливаем Item на начало списка

while Item< > nil do begin // пока не достигнут конец списка L

if (Item^.Value< 0) and odd(Item^.Value) // нечетные отрицательные

then InsertLast(L1, Item^.Value); // включаем в список L1

if (Item^.Value> 0) and not odd(Item^.Value) // положительные четные

then InsertLast(L2, Item^.Value); // включаем в список L2

Item: =Item^.Next; // сдвигаем Item на следующий элемент

end; // while

end; // procedure FormLists

var

fDat, fRes: Text; // файлы с исходными данными и результатами работы

L, L1, L2: pItem; // указатели на исходный и результирующие списки

v: tValue; // значение элемента списка

begin

Assign(fDat, 'LW3Dat.txt'); Reset(fDat); // открытие файла для чтения

Assign(fRes, 'LW3Res.txt'); Rewrite(fRes); // открытие файла для записи

Create(L); Create(L1); Create(L2); // создание пустых списков

while not eof(fDat) do begin // пока не достигнут конец файла fDat:

Read(fDat, v); // чтение из файла очередного значения в v,

InsertFirst(L, v); // вставка элемента со значением v в начало списка L

end; // while

Writeln(fRes, 'Исходный список: '); WriteList(fRes, L); // вывод списка L

Writeln(fRes, 'Число элементов списка: ', Size(L)); // вывод размера L

FormLists(L, L1, L2); // формирование списков L1 и L2

Writeln(fRes, 'Список отрицательных нечетных элементов: ');

WriteList(fRes, L1); // вывод списка L1

Writeln(fRes, 'Число элементов списка: ', Size(L1)); // вывод размера L1

Writeln(fRes, 'Список положительных четных элементов: ');

WriteList(fRes, L2); // вывод списка L2

Writeln(fRes, 'Число элементов списка: ', Size(L2)); // вывод размера L2

Clear(L); Clear(L1); Clear(L2); // удаление списков

Close(fDat); Close(fRes); // закрытие файлов

end.

Тема 2. МОДУЛИ

1. Назначение модулей

Наличие модулей в Delphi позволяет:

1) создавать библиотеки программных элементов – подпрограмм, констант, типов и переменных;

2) практически неограниченно увеличивать кодовую часть программы;

3) использовать подпрограммы, константы, типы и переменные, содержащиеся в стандартных модулях (поставляемых в составе системы программирования Delphi) и в модулях других программистов;

4) программировать и отлаживать программу по частям.

Модуль состоит из следующих частей:

· заголовок модуля;

· секция интерфейса;

· секция реализации;

· секция инициализации;

· секция деинициализации.

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

2. Заголовок модуля

Заголовок модуля состоит из зарезервированного слова unit и идентификатора. Идентификатор модуля должен быть уникальным. Пример заголовка:

unit MyModule;

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

3. Секция интерфейса

Секции интерфейса выполняет представительскую функцию, – в ней указываются константы, типы, переменные, процедуры и функции, которые могут быть использованы в основной программе или в другом модуле при подключении данного модуля.

Секция начинается зарезервированным словом interface. Далее могут размещаться: 1) предложение uses, в котором перечисляются имена модулей, используемых данным модулем; 2) раздел описания констант; 3) раздел описания типов; 4) раздел описания переменных; 5) раздел описания процедур и функций. Порядок следования разделов описаний так же, как и в главной программе, может быть произвольным. Возможно повторение разделов. Требуется только одно: используемое сейчас должно быть описано выше. Любой из подразделов может отсутствовать. Допустима даже пустая секция интерфейса, но модуль с такой секцией никому не нужен.

В разделе объявления процедур и функций указываются лишь заголовки подпрограмм. Сами подпрограммы (их блоки) размещаются в секции реализации.

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

4. Секция реализации модуля

Назначение секции реализации – реализация подпрограмм, заявленных в секции интерфейса.

Секция начинается зарезервированным словом implementation. Далее могут размещаться: 1) предложение uses, в котором перечисляются имена модулей, используемых данным модулем, но не упомянутые в предложении секции uses интерфейса; 2) раздел описания меток; 3) раздел описания констант; 4) раздел описания типов; 5) раздел описания переменных; 6) раздел описания процедур и функций.

Структурно секция реализации отличается от секции интерфейса только тем, что разрешено наличие раздела описаний меток.

Как и в секции интерфейса: 1) порядок следования разделов описаний может быть произвольным; 2) возможны повторения разделов; 3) действует правило: используемое сейчас должно быть описано выше; 4) любой из подразделов может отсутствовать; 5) допустима пустая секция реализации.

Модули с пустой секцией реализации не так уж и бесполезны, более того, они часто используются. Естественно, что при этом в секции интерфейса не должно содержаться описаний подпрограмм, допустимы только константы, типы и переменные.

Раздел описания подпрограмм обязательно должен содержать описания подпрограмм, заявленных (описанных) в секции интерфейса. В описаниях этих подпрограмм допустимо использовать сокращенные заголовки без списков формальных параметров. Описания каждой подпрограмм обязательно содержит её блок (тело), состоящее из раздела описаний и раздела операторов.

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

Важно понимать, что все метки, константы, типы, переменные и подпрограммы, описанные в секции реализации, кроме подпрограмм из секции интерфейса, являются локальными элементами данного модуля, они не видны из других программ и модулей, они создаются только с одной целью – реализовать подпрограммы секции интерфейса!

5. Секция инициализации

Секция инициализации – факультативная часть модуля. В ней размещаются операторы, которые выполняются в начале работы той программы, которая использует данный модуль. Если программа использует несколько модулей, то содержимое их секций инициализации выполняется в порядке перечисления имён модулей в предложении uses. Эта секция начинается зарезервированным словом initialization, например:


Поделиться с друзьями:

mylektsii.su - Мои Лекции - 2015-2025 год. (0.019 сек.)Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав Пожаловаться на материал