Банк рефератов содержит более 364 тысяч рефератов, курсовых и дипломных работ, шпаргалок и докладов по различным дисциплинам: истории, психологии, экономике, менеджменту, философии, праву, экологии. А также изложения, сочинения по литературе, отчеты по практике, топики по английскому.
Полнотекстовый поиск
Всего работ:
364139
Теги названий
Разделы
Авиация и космонавтика (304)
Административное право (123)
Арбитражный процесс (23)
Архитектура (113)
Астрология (4)
Астрономия (4814)
Банковское дело (5227)
Безопасность жизнедеятельности (2616)
Биографии (3423)
Биология (4214)
Биология и химия (1518)
Биржевое дело (68)
Ботаника и сельское хоз-во (2836)
Бухгалтерский учет и аудит (8269)
Валютные отношения (50)
Ветеринария (50)
Военная кафедра (762)
ГДЗ (2)
География (5275)
Геодезия (30)
Геология (1222)
Геополитика (43)
Государство и право (20403)
Гражданское право и процесс (465)
Делопроизводство (19)
Деньги и кредит (108)
ЕГЭ (173)
Естествознание (96)
Журналистика (899)
ЗНО (54)
Зоология (34)
Издательское дело и полиграфия (476)
Инвестиции (106)
Иностранный язык (62791)
Информатика (3562)
Информатика, программирование (6444)
Исторические личности (2165)
История (21319)
История техники (766)
Кибернетика (64)
Коммуникации и связь (3145)
Компьютерные науки (60)
Косметология (17)
Краеведение и этнография (588)
Краткое содержание произведений (1000)
Криминалистика (106)
Криминология (48)
Криптология (3)
Кулинария (1167)
Культура и искусство (8485)
Культурология (537)
Литература : зарубежная (2044)
Литература и русский язык (11657)
Логика (532)
Логистика (21)
Маркетинг (7985)
Математика (3721)
Медицина, здоровье (10549)
Медицинские науки (88)
Международное публичное право (58)
Международное частное право (36)
Международные отношения (2257)
Менеджмент (12491)
Металлургия (91)
Москвоведение (797)
Музыка (1338)
Муниципальное право (24)
Налоги, налогообложение (214)
Наука и техника (1141)
Начертательная геометрия (3)
Оккультизм и уфология (8)
Остальные рефераты (21692)
Педагогика (7850)
Политология (3801)
Право (682)
Право, юриспруденция (2881)
Предпринимательство (475)
Прикладные науки (1)
Промышленность, производство (7100)
Психология (8692)
психология, педагогика (4121)
Радиоэлектроника (443)
Реклама (952)
Религия и мифология (2967)
Риторика (23)
Сексология (748)
Социология (4876)
Статистика (95)
Страхование (107)
Строительные науки (7)
Строительство (2004)
Схемотехника (15)
Таможенная система (663)
Теория государства и права (240)
Теория организации (39)
Теплотехника (25)
Технология (624)
Товароведение (16)
Транспорт (2652)
Трудовое право (136)
Туризм (90)
Уголовное право и процесс (406)
Управление (95)
Управленческие науки (24)
Физика (3462)
Физкультура и спорт (4482)
Философия (7216)
Финансовые науки (4592)
Финансы (5386)
Фотография (3)
Химия (2244)
Хозяйственное право (23)
Цифровые устройства (29)
Экологическое право (35)
Экология (4517)
Экономика (20644)
Экономико-математическое моделирование (666)
Экономическая география (119)
Экономическая теория (2573)
Этика (889)
Юриспруденция (288)
Языковедение (148)
Языкознание, филология (1140)

Курсовая работа: Создание базы данных о поездах дальнего следования

Название: Создание базы данных о поездах дальнего следования
Раздел: Рефераты по информатике
Тип: курсовая работа Добавлен 21:25:47 23 декабря 2009 Похожие работы
Просмотров: 44 Комментариев: 15 Оценило: 1 человек Средний балл: 5 Оценка: неизвестно     Скачать

Федеральное агентство Российской Федерации по атомной энергии

Снежинская государственная физико-техническая академия

КУРСОВОЙ ПРОЕКТ

На тему:

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

Снежинск 2006


Реферат

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

1. Описание программы и её модулей

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

int main()

{pp=1; T=0;

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

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

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

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

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

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

clrscr();

}

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

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;

}

Просмотрим функции для реализации программы:

1) Функция TREE *der (TREE *kr, SISTEMA word)

{if (kr==NULL)

{kr=new TREE;

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);

else kr->r=der (kr->r, word;

return kr;

)

Функция предназначена для формирования дерева. Если дерево пустое, записываем информацию в вершину. Выделяется память под новый элемент, сравнивается поступившая информация с информацией в узле. Если элементы одинаковы, включается счётчик.

2) Функция void Crt _ Der ()

{

SISTEMAa;

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);

}

}

}

Функция предназначена для записи в дерево информации и вывод дерева на экран.

3) Функция 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);

}

}

Функция предназначена для печати дерева. В print_der (kr->l) используется обход левых ветвей, иначе в print_der (kr->r) обход правых ветвей.

4) Функция 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);

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);

}

Функция предназначена для поиска по номеру поезда. Осуществляется поиск элемента с заданным ключом. Используется рекурсивный обход.

5) Функция 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);

}

}

Функция предназначена для поиска по названию станции. Осуществляется поиск элемента с заданным ключом. (q=d – сохраняем предыдущую вершину, fl=1 – двигаемся влево,

Poisk_st (d->l, s) – спускаемся влево, fl=0 – двигаемся вправо, Poisk_st (d->l, s) – спускаемся вправо). Используется рекурсивный обход.

2. Программная документация

Техническое задание, определяющее требования, предъявляемые к ПО, необходимые стадии и сроки разработки, виды испытаний

1. Введение.

Программа «Расписание ж/д 2007» применяется в работе на ж/д вокзалах оператором и обычными пользователями, т.е. людьми.

2. Основание для разработки.

Разработка этого изделия ведется на основании помощи в работе по легкости создания и введения изменений в расписание поездов дальнего следования.

3. Назначение разработки.

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

4. Требования к программе:

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

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

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

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

5. Требования к программной документации.

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

6. Технико-экономические показатели.

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

7. Этапы разработки.

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

8. Порядок контроля и приемки.

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

Программа и методика испытаний

1. Объект испытаний.

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

Техническое задание:

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

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

2) Название станции

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

Поиск осуществлять по номеру поезда и по названию станции.

2. Цель проведения испытаний.

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

3. Требования к программе.

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

4. Требования к программной документации.

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

5. Порядок проведения испытаний.

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

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

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

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

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

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

1. Функция TREE *der (TREE*kr, SISTEMAword) – предназначена для формирования дерева. Если дерево пустое, записываем информацию в вершину. Выделяется память под новый элемент, сравнивается поступившая информация с информацией в узле. Если элементы одинаковы, включается счётчик.

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

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

4. Функция intPoisk_nom_p (TREE*d, intv) – предназначена для поиска по номеру поезда.

5. Функция intPoisk_st (TREE*d, chars[20]) – предназначена для поиска по названию станции.

Описание программы, в которой содержатся сведения о логической структуре и функционировании ПО

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

Программа называется «Расписание ж/д 2007». Язык программирования, на котором написана программа – С++.

2. Функциональное назначение.

Классы решаемых задач:

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

2) Чтение базы данных.

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

4) Поиск по названию станции назначения.

3. Описание логической структуры.

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

3.4. Функция intPoisk_st (TREE*d, chars[20]) – предназначена для поиска по названию станции.

4. Входные данные.

Должны быть введены такие данные как: номер поезда, станция назначения, время отправления:

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

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

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

5. Выходные данные.

Должны соответствовать входным данным:

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

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

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

Обычно программы разрабатываются в расчете на то, чтобы ими могли пользоваться люди, не участвующие в их разработке (их называют пользователями). Для освоения программы пользователем помимо ее текста требуется определенная дополнительная документация. Программа или логически связанная совокупность программ на носителях данных, снабженная программной документацией, называется программным средством (ПС). Программа позволяет осуществлять некоторую автоматическую обработку данных на компьютере. Программная документация позволяет понять, какие функции выполняет та или иная программа ПС, как подготовить исходные данные и запустить требуемую программу в процесс ее выполнения, а также: что означают получаемые результаты (или каков эффект выполнения этой программы). Кроме того, программная документация помогает разобраться в самой программе, что необходимо, например, при ее модификации.

1. Назначение и область применения.

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

2. Технические характеристики.

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

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

Описание алгоритма и программы.

Программа начинает работать со специального меню, в котором описаны следующие пункты:

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

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

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

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

При помощи этого меню пользователь может выбрать нужный ему пункт, а также посмотреть интересующую его информацию.

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

Второй пункт предназначен для просмотра общей информации;

Третий пункт предназначен для пользователей. В строке «Введите номер поезда» вводится искомый номер поезда и после нажатия Enter программа осуществляет поиск по номеру поезда. В результате выдаются сведения о станции назначения и времени отправления.

Четвертый пункт также предназначен для пользователя. В строке «Введите станцию назначения» вводится искомая станция назначения и после нажатия Enter программа осуществляет поиск по названию станции. В результате выдаются сведения о номере поезда и времени отправления. Если до станции назначения идут поезда и в разное время, то на экран выводятся все данные о поездах идущих до этой станции.

Пятый пункт предназначен для возврата к самой программе.

Выбор алгоритма произведен на основании метода «Двоичное дерево».

3. Ожидаемые технико-экономические показатели.

Преимущество выбранного варианта технического решения: удобная и облегченная работа для персонала.

4. Источники, используемые при разработке.

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

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

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

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

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) Функция voidCrt_Der() – предназначена для записи в дерево информации и вывод дерева на экран.

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

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

4) Функция intPoisk_st (TREE*d, chars[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», 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++; // элементы одинаковы, включается счетчик

elseif (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);

}

}

Оценить/Добавить комментарий
Имя
Оценка
Комментарии:
Хватит париться. На сайте FAST-REFERAT.RU вам сделают любой реферат, курсовую или дипломную. Сам пользуюсь, и вам советую!
Никита15:04:05 05 ноября 2021
.
.15:04:03 05 ноября 2021
.
.15:04:00 05 ноября 2021
.
.15:03:57 05 ноября 2021
.
.15:03:55 05 ноября 2021

Смотреть все комментарии (15)
Работы, похожие на Курсовая работа: Создание базы данных о поездах дальнего следования

Назад
Меню
Главная
Рефераты
Благодарности
Опрос
Станете ли вы заказывать работу за деньги, если не найдете ее в Интернете?

Да, в любом случае.
Да, но только в случае крайней необходимости.
Возможно, в зависимости от цены.
Нет, напишу его сам.
Нет, забью.



Результаты(294399)
Комментарии (4230)
Copyright © 2005 - 2024 BestReferat.ru / реклама на сайте