C语言飞机订票系统.docx
C语言飞机订票系统数据结构课程设计报告之飞机订票系统 一、需求分析: 在完成课程设计的过程中,我们组合作为主,.主要负责程序设计与调试,.主要负责资料收集与文档输入。设计完成后交流了各人收获与体会。 航空订票系统: 通过此系统可以实现如下功能: 1) 录入航线信息 每条航线信息包括航班号、飞机号、目的地、订票数、余票数共5项。假设现在有3条航线, 目的地分别是北京, 上海, 广州, 飞机上可乘坐100人( 即初始订票数为0, 余票数为100) , 将这3条航线信息存入文件“airline.dat” 中。 2) 订票业务 客户信息包括姓名, 航班号, 座位号(初始为0), 假设已有3个客户信息存入文件“customer.dat”中。 有 新客户订票时, 先输入客户的姓名和他提出的航班号, 查询该航线的订票情况, 若有余票, 则为客户办理订票手续, 分配给客户一个座位号, 然后将新客户的信息添加到文件“customer.dat”中, 并修改文件“airline.dat”中该航线的订票数和余票数。若无余票, 则输出客满信息。进一步可实现如果该航班已经无票,可以提供相关可选择航班信息。 3) 退票业务 根据客户提出的航班号, 办理退票, 从文件“customer.dat”中删除该客户的信息, 并修改文件“airline.dat”中相应航线的订票数和余票数。 4) 修改航班信息:当航班信息改变可以修改航班数据文件。 5) 输出全部航线信息和全部客户信息。 6) 退出系统。 二、 概要设计: 航空订票系统: 1)、抽象数据类型定义如下: typedef struct airline char line_num8;/航班号 char plane_num8;/飞机号 char end_place20;/目的的 int total;/座位总数 int left;/剩余座位 struct airline *next;/下一个结点 airline; typedef struct customer char name9;/顾客名 char line_num8;/航班号 int seat_num;/座位号 struct customer *next;/下一个结点 customer; /*链表操作模块*/ airline *init_airline; /初始化链表 customer * init_customer; /初始化链表 status insert_airline(airline *p,char *line_num,char *plane_num,char *end_place,int total,int left); /airline链表插入操作 /插入航班 status insert_customer(customer *p,char *name,char *line_num,int seat); /customer链表插入操作 status creat_airline(airline *l); /创建airline单链表 status creat_customer(customer *l); /创建customer单链表 /*链表操作模块*/ 2)、其它模块的实现函数声明如下: /*信息修改*/ airline *modefy_airline(airline *l,char *line_num); /修改airline链表中的数据 status delete_airline(airline *h,char *line_num); /删除航班 status delete_customer(customer *h,char *line_num); /删除顾客 status delete_cus(customer *h,airline *l,char *name); /顾客退票 status increase_air(airline *l,char *line_num,char *plane_num,char *end_place,int total); /增加航线 /*信息修改*/ /*文件操作模块*/ status save_airline(airline const *l); /保存airline.dat status save_customer(customer const *l); /保存顾客信息 customer.dat /*文件操作模块*/ int changStrInt(char *ch); /把字符串转化为整型 status book(airline const *l,char *line_num,customer *c,char *name); /订票 status print_airline(airline const *l); /打印航线信息 status print_customer(customer const *l); /打印顾客信息 status air_main; /执行函数 三、详细设计: 所需抽象数据类型定义和一些函数的声明见设计概要。 这里只解释一下执行函数和一些比较复杂一点的算法。 .