Курсовая работа: Обработка динамических структур
3.1 Схема работы программы
Считать номер n пункта меню:
1. Если n=1, вызвать функцию vvodSp. Формирование списка.
2. Если n=2, вызвать функцию loadIT. Считывание списков из файлов.
3. Если n=3 , вызвать функцию sort. Сортировка первого списка по фамилиям автора.
4. Если n=4, вызвать функцию vivodSp. Вывод первого (текущего) списка на печать.
5. Если n=5, вызвать функцию vivodSp. Вывод второго списка (выданных на руки книг) на печать.
6. Если n=6, вызвать функцию dobEl. Добавление нового элемента в конец списка и последующая сортировка по имени автора.
7. Если n=7, вызвать функцию delel. Удаление всех записей с введённой фамилией автора.
8. Если n=8, вызвать функцию vidacha. Добавление книги во второй список, удаление из первого.
9. Если n=9, вызвать функцию vozvrat. Удаление книги из второго списка, добавление в первый.
10. Если n=10, вызвать функцию saveIT. Запись данных первого и второго списков в файлы.
11. Если n=11, выполнить выход из программы.
Блок схемы основной программы и функций vvodSp, dobEl, delel представлены в приложениях соответственно А, Б, В, Г.
3.2 Стандартные процедуры и функции, используемые в программе
В процессе разработки программы были использованы стандартные модули языка программирования С: stdio.h, alloc.h, conio.h, string.h,.
Модуль stdio.h позволяет работать с потоками (строки, файлы…). Данный модуль включает такие необходимые функции как scanf(), printf(), gets(), puts(), и набор функций для работы с файлами.
Модуль alloc.h предназначен для работы с динамической памятью, в нем содержатся функции calloc(), malloc(), free() и константа NULL.
Модуль string.h предназначен для работы со строками, точнее строковым типом данных. В нем находятся функции для копирования, сравнения, склеивания, и поиска подстроки. В программе используются две стандартные функции этого модуля: strwr и strcmp. Первая преобразует строчные символы строки в прописные. Данная функция необходима для предотвращения ошибок ввода из-за восприимчивости программы к регистру. Функция strcmp(Строка1, Строка2) сравнивает строки Строка1 и Строка2, возвращает 0, если строки равны; число меньше нуля, если первая строка меньше второй; число больше нуля, если первая строка больше второй.Модуль conio.h предназначен для работы с экраном в текстовом режиме. В нем хранятся функции для очистки экрана, изменения цвета текста и фона, атрибутов текста, процедуры для буферизированного и небуферизированного ввода с клавиатуры.
3.3 Описание работы пользовательских подпрограмм
3.3.1 Описание работы подпрограммы vvodSp
Подпрограмма предназначена для формирования первого списка. Функция возвращает указатель на начало первого списка. Входной параметр – указатель на указатель на начало второго списка.
1. Обнулить указатели на начала и хвосты обоих списков.
2. Пока не будет введено "no" выполнять:
2.1 Динамически выделить память под указатель на текущий элемент.
2.2 Обнулить указатель на следующий за текущим элемент.
2.3 Присвоить указателю на предшествующий текущему элемент адрес предыдущего элемента.
2.4 Если указатель на начало списка обнулён, то присвоить вершине списка адрес текущего элемента, то есть текущий элемент становится вершиной.
2.5 Иначе, присвоить указателю на следующий за предыдущим элемент списка адрес текущего элемента.