Эксплуатационная документация




 

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

При эксплуатации программа ведёт себя таким образом:

1. Создание дерева.

Вводим номер поезда, название станции и время отправления поезда. После того как ввели все данные в строке «Введите номер поезда: (-1 – выход)» вводим -1 для того чтобы выйти в основное меню.

Протестированный ответ:

Введите номер поезда: (-1 – выход) 2

Введите название станции: Moskva

Введите время отправления: 13.05

Номер поезда 2

Станция назначения Moskva

Время отправления 13.05

Введите номер поезда: (-1 – выход) 1

Введите название станции: Kasli

Введите время отправления: 12.10

Номер поезда 1

Станция назначения Kasli

Время отправления 12.10

Введите номер поезда: (-1 – выход) 3

Введите название станции: Kasli

Введите время отправления: 15.35

Номер поезда 3

Станция назначения Kasli

Время отправления 15.35

Введите номер поезда: (-1 – выход) 5

Введите название станции: Kirov

Введите время отправления: 11.55

Номер поезда 5

Станция назначения Kirov

Время отправления 11.55

Введите номер поезда: (-1 – выход) 4

Введите название станции: Volgograd

Введите время отправления: 17.55

Номер поезда 4

Станция назначения Volgograd

Время отправления 17.55

Введите номер поезда: (-1 – выход) – 1

2. Чтение дерева.

При вызове этого пункта меню просматривается вся введенная информация в пункте 1. Для выхода в основное меню нужно нажать Enter.

Протестированный ответ:

Номер поезда 1

Станция назначения Kasli

Время отправления 12.10

Номер поезда 2

Станция назначения Moskva

Время отправления 13.05

Номер поезда 3

Станция назначения Kasli

Время отправления 15.35

Номер поезда 4

Станция назначения Volgograd

Время отправления 17.55

Номер поезда 5

Станция назначения Kirov

Время отправления 11.55

3. Поиск по номеру поезда.

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

Протестированный запрос:

Введите номер поезда: 4

Протестированные ответы:

Станция назначения Volgograd

Время отправления 17.55

Протестированный запрос:

Введите номер поезда: 7

Протестированный ответ:

Элемент с заданным ключом не найден

4. Поиск по названию станции в дереве.

Для поиска по такой информации нужно ввести предварительные данные такие как: станция назначения. Если такой поезд на данный момент совершает рейс, также он может быть не один, то поисковая база выведет на табло все данные об этих поездах. Если же такого поезда нет, то на табло высветится фраза «Элемент с заданным ключом не найден».

Протестированный запрос:

Введите станцию назначения: Kasli

Протестированные ответы:

Номер поезда 1

Время отправления 12.10

Номер поезда 3

Время отправления 15.35

Протестированный запрос:

Введите станцию назначения: Krasnodar

Протестированный ответ:

Элемент с заданным ключом не найден

Формуляр, который определяет основные характеристики ПО, комплектность и сведения об эксплуатации

1. Общие указания.

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

1. Общие сведения.

Наименование программного изделия – «Расписание ж/д 2007». Это пробная программа для улучшения деятельности оператора ж/д вокзала. Программный продукт поможет с легкостью создавать базу данных и осуществлять поиск данных по ней. В работе не применяется сложных операций, поэтому с этой программой легко работать.

2. Основные характеристики.

Вся программа основывается на функциях:

1) Функция void Crt_Der() – предназначена для записи в дерево информации и вывод дерева на экран.

2) Функция void print_der (TREE *kr) – предназначена для печати дерева.

3) Функция int Poisk_nom_p (TREE *d, int v) – предназначена для поиска по номеру поезда.

4) Функция int Poisk_st (TREE *d, char s[20]) – предназначена для поиска по названию станции.

Эти функции и выполняют главные задачи, предназначенные выполнению программе.

3. Комплектность.

Других программных изделий в это программное изделие не входит. Ведомость эксплуатационных документов можно посмотреть в Приложении 2.

4. Периодический контроль.

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

Вводимые данные:

Введите номер поезда: (-1 – выход) 1

Введите название станции: Kasli

Введите время отправления: 12.10

Контроль за данными:

Номер поезда 1

Станция назначения Kasli

Время отправления 12.10

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

1. Назначение программы.

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

2. Описание задачи.

Задача реализована с помощью меню в котором описаны начальные данные о:

1) Создание базы данных о поездах дальнего следования.

2) Просмотр полученной информации.

1) Осуществить поиск в базе данных по номеру поезда.

Осуществить поиск в базе данных по названию станции назначения.

Эти пункты более подробно объяснены в Приложении 1.

3. Входные и выходные данные.

Если посмотреть, как работает программа (пример ее реализации показан в Приложении 2), то можно убедиться что выходные данные полностью соответствуют входным, а это значит что программа работает корректно.

 

 


Заключение

 

В нашем случае мы использовали для написания программы двоичное дерево поиска. Закрепили теоретические знания и приобрели практические навыки по изучаемой дисциплине при разработке программного обеспечения для организации работы ж/д вокзала. А также выполнили задачи курсового проектирования:

– изучили особенности работы вокзала;

– анализировали возможные подходы и методы решения с обоснованием выбранного подхода;

– выбрали модель, необходимую для достижения цели;

– выбрали эффективные алгоритмы с учетом их точности, устойчивости, сходимости;

– разработали программное обеспечение;

– анализировали полученные результаты работы ПО.

Так как людям стало удобнее получать деньги и класть денежные средства на мобильные телефоны через банкоматы, то большая перспектива лежит в дальнейшем развитии «Расписание ж/д 2007». Это будет более удобный вариант для просмотра информации, не будет создаваться больших очередей возле касс, для того чтобы только спросить, оператору удобнее смотреть на экран и оповещать зал ожидания.

 

 


Литература

1. Герберт Шилдт Теория и практика на С++: пер. с англ. – СПб.: BNV – Санктл-Петербург, 1996.-416 с.

2. Павловская Т.А. С/С++. Программирование на языке высокого уровня – СПб: Питер, 2004. – 461 с.: ил.

3. Хусаинов Б.С. Структуры и алгоритмы обработки данных. Примеры на языке Си: Учеб. пособие. – Финансы и статика, 2004. – 464 с.: ил. Березин Б.И.

4. Березин С.Б. Начальный курс С и С++ – М.: ДИАЛОГ – МИФИ, 1996 – 288 с.

5. Кузин А.В. Базы данных: Учеб. пособие для студ. высш. учеб. заведений / А.В. Кузин, С.В. Левонисова. – М.: Издательский центр «Академия», 2005. – 320 с. ISBN 5–7695–1796–4

 


Приложение 1

 

Программа:

#include<stdio.h>

#include<conio.h>

#include<alloc.h>

#include<string.h>

#include<io.h>

#define k 5

#define TREE struct der

struct SISTEMA

{char st[20]; // станция назначения

int nom_p; // nom_p‑номер поезда

float vr; //vr‑время отправления

};

TREE

{SISTEMA w;

int c; // счетчик повторяющихся элементов

TREE *l; // ссылка влево

TREE *r; // ссылка вправо

};

TREE *q,*pr,*nom,*kr=0; // ссылки на корень дерева

SISTEMA *T;

char *menu[k] [60];

int i, pp, m; char key[20]; char name[20];

int Main_Menu(void); // функция меню

int Poisk_nom_p (TREE *d, int v); // поиск по номеру поезда

TREE *der (TREE *kr, SISTEMA word); // формирование дерева

void Crt_Der(); // Запись в дерево информации и вывод дерева на экран

void print_der (TREE *kr); // Печать дерева

int Poisk_st (TREE *d, char s[20]); // поиск по станции назначения

int main()

{pp=1; T=0;

*menu[0]= «1. Создание дерева»;

*menu[1]= «2. Чтение дерева»;

*menu[2]= «3. Поиск по номеру в дереве»;

*menu[3]= «4. Поиск по названию станции в дереве»;

*menu[4]= «5. Конец работы»;

*menu[5]= «Введите номер строки:»;

clrscr();

printf (««Расписание ж/д 2007»\n»);

while(pp)

{Main_Menu();

clrscr();

}

printf («Конец работы с деревьями\n»);

return 0;

}

/*Функция меню*/

Main_Menu(void)

{int ns, s;

flushall();

do

{for (i=0; i<k; i++)

printf («\n % s»,*menu[i]);

printf («\n»);

if (s=((scanf («%d»,&ns)<1)))

{flushall(); clrscr();

printf («\n Ошибка в номере!! Будте внимательны»);

}

}

while(s);

switch(ns)

{case 1: Crt_Der(); break;

case 2: print_der(kr);

getche();

break;

case 3:

/*Поиск по времени*/

printf («\n Введите номер поезда:»);

int v;

scanf («%d»,&v);

Poisk_nom_p (kr, v); break;

case 4:

/*Поиск по станции назначения*/

int sr/*, fl*/;

char s[20];

printf («\n Введите станцию назначения:»);

scanf («%s», s);

Poisk_st (kr, s); break;

case 5: pp=0;

} return 0;

}

/*Формирование дерева*/

TREE *der (TREE *kr, SISTEMA word)

{if (kr==NULL) // дерево пустое, записываем информацию в вершину

{kr=new TREE; // выделяется память под новый элемент

//printf («\n % d % s%.2f», word.nom_p, word.st, word.vr);

printf («\n Номер поезда % d», word.nom_p);

printf («\n Станция назначения % s», word.st);

printf («\n Время отправления%.2f», word.vr);

kr->w=word; // присваиваем информацию

kr->c=1;

kr->l=kr->r=NULL;

}

else if (word.nom_p==kr->w.nom_p) // сравниваем поступившую информацию с информацией в узле

kr->c++; // элементы одинаковы, включается счетчик

else if (word.nom_p<kr->w.nom_p) kr->l=der (kr->l, word); // пока не встретится 0

else kr->r=der (kr->r, word); // иначе вправо

return kr;

}

/*Запись в дерево информации и вывод дерева на экран*/

void Crt_Der()

{

SISTEMA a;

a.nom_p=0;

while (a.nom_p!=-1)

{

printf («\n Введите номер поезда: (-1 – выход)»);

scanf («%d», &a.nom_p);

if (a.nom_p==-1)

break;

flushall();

{printf («\n Введите название станции:»);

scanf («%s», a.st);

printf («\n Введите время отправления:»);

scanf («%f», &a.vr);

if (a.nom_p!=-1)

kr=der (kr, a);

}

}

}

/*Печать дерева*/

void print_der (TREE *kr)

{if(kr)

{print_der (kr->l); // обход левых ветвей

printf («\n Номер поезда % d», kr->w.nom_p);

printf («\n Станция назначения % s», kr->w.st);

printf («\n Время отправления%.2f», kr->w.vr);

printf («\n»);

print_der (kr->r); // обход правых ветвей

}

}

/*Поиск по номеру поезда*/

int Poisk_nom_p (TREE *d, int v)

{

if (d==NULL)

{

printf («\n \t Элемент с заданным ключом не найден\n»);

return 0;

}

else // Поиск элемента с заданным ключом

{if (v==d->w.nom_p)

{

printf («\n Станция назначения % s», d->w.st);

printf («\n Время отправления%.2f», d->w.vr);

// print_der(kr);

getch();

}

/*Рекурсивный обход*/

if (v<d->w.nom_p) Poisk_nom_p (d->l, v);

if (v>d->w.nom_p) Poisk_nom_p (d->r, v);

 

}

}

/*Поиск по названию станции*/

int Poisk_st (TREE *d, char s[20])

{int sr, fl;

if (d==NULL)

printf («\n \t Элемент с заданным ключом не найден\n»);

else // Поиск элемента с заданным ключом

{sr=strcmp (s, d->w.st);

if (sr<0)

{q=d; // сохраняем предидущую вершину

fl=1; // двигаемся влево

Poisk_st (d->l, s); // спускаемся влево

}

else

if (sr>0)

{q=d; // сохраняем предидущую вершину

fl=0; // двигаемся вправо

Poisk_st (d->r, s); // спускаемся вправо

}

else // нужный ключ (станция назначения) найден

{if (sr==0)

printf («\n Номер поезда % d», kr->w.nom_p);

printf («\n Время отправления%.2f», kr->w.vr);

getch();

}

/*Рекурсивный обход*/

if (s<d->w.st) Poisk_st (d->l, s);

if (s>d->w.st) Poisk_st (d->r, s);

}

}



Поделиться:




Поиск по сайту

©2015-2024 poisk-ru.ru
Все права принадлежать их авторам. Данный сайт не претендует на авторства, а предоставляет бесплатное использование.
Дата создания страницы: 2020-04-01 Нарушение авторских прав и Нарушение персональных данных


Поиск по сайту: