数据结构课程教学设计-飞机订票系统设计与实现(里面附有源代码)_第1页
数据结构课程教学设计-飞机订票系统设计与实现(里面附有源代码)_第2页
数据结构课程教学设计-飞机订票系统设计与实现(里面附有源代码)_第3页
数据结构课程教学设计-飞机订票系统设计与实现(里面附有源代码)_第4页
数据结构课程教学设计-飞机订票系统设计与实现(里面附有源代码)_第5页
已阅读5页,还剩66页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、程设计题目飞机订票系统专业姓名*学号*指导教师*2012 年 7 月1. 需求分析1.1 问题描述基于目前人们外出远行频繁,为方便乘客提前买票及优化飞机航空订票服务,需要开发一个飞机订票系统,此程序就是要实现航班情况的录入,查询,订票,退票以及航班的查询和修改等基本功能。本课程设计的题目为:飞机订票系统。1.2 基本要求1.2.1 输入的形式和输入值的范围录入航班信息时,需要输入航班号,起降时间,起飞抵达城市,值为字符串;还需要输入航班票价,票价折扣,值为浮点型( float ) ; 还需要输入航班是否满仓,值为整型 ( int )( “ 1”表示已满仓, “ 0”表示没有满仓) ;如需要继续

2、录入航班信息,要输入判别信息,值为整型(“ 1 ”表示继续录入航班信息, “ 0”表示停止录入航班信息)。客户订票时,需要输入起飞抵达城市,然后选择航班进行查询,选择航班时需要输入航班号,值为字符串。客户退票时,需要输入姓名,证件号进行退票操作,值为字符串。查询某个航班的情况时,需要输入航班号,值为字符串;在查询某个航线的情况时,还可以通过输入起飞抵达城市来查询,值为字符串。查询某个订单时,需要输入订单号,值为整型(int ) ;或者需要输入客户姓名和证件号,值为字符串。修改航班时,需要输入字符型数据选择进行何种修改操作;增加航班时,需要输入航班号,起降时间,起飞抵达城市,值为字符串;还需要输

3、入航班票价,票价折扣,值为浮点型( float ) ;还需要输入航班是否满仓,值为整型(int ) ( “ 1”表示已满仓, “ 0”表示没有满仓);如需要继续录入航班信息,要输入判别信息,值为整型(“ 1 ”表示继续录入航班信息,“ 0”表示停止录入航班信息);删除航班时,需要输入要删除的航班的航班号;修改航班时间时,需要输入要修改的航班的航班号,修改后的航班起飞时间和抵达时间。1.2.2 输出形式在所有操作后的输出中都显示操作是否正确以及操作后单链表的内容。其中删除操作后显示删除的元素的值,查找操作后显示要查找元素的位置。录入航班情况时,输出显示添加航班信息是否成功。客户订票时,当客户输入

4、起飞抵达城市后,输出可供客户选择的航班信息;客户选择了航班后,输入提示信息告知用户订票是否成功。客户退票时,输出客户退票成功或者无此客户,无法退票。查询航班时,输出显示对应的航班信息,或者输出提示信息告知没有相应的航班信息。查询订单时,输出显示对应的订单信息,或者输出提示信息告知没有相应的订单信息。修改航班时,输出对应的提示的信息,提示操作是否成功。1.2.3 功能要求( 1 )可以录入航班情况,数据存储在一个数据文件中;( 2 )可以查询某个航线的情况:输入航班号,查询起降时间,起飞抵达城市,航班票价,票价折扣,确定航班是否满仓;输入起飞抵达城市,查询飞机航班情况;( 3 )可以订票,订票情

5、况存在一个数据文件中(如果该航班已经无票,提供相关可选航班) ;( 4)可退票并且退票后修改相关数据文件;( 5 )客户资料:姓名,证件号,订票数量及航班情况,订单要有编号;( 6 )修改航班信息,当航班信息改变可修改航班数据文件;( 7 )要求:根据以上功能说明,设计航班信息,订票信息的存储结构,设计程序完成功能。2. 概要设计2.1 数据结构( 1 )航班的信息:航班的情况存储结构采用单链表,每个元素表示一个航班的情况,包括航班号、起飞时间、降落时间、起飞城市、抵达城市、航班票价、票价折扣、确定航班是否满仓和空座数九个数据项:航班号起飞时间降落时间起飞城市抵达城市航班是否满仓空座数票价票价

6、折扣字符串字符串字符串字符串字符串整数整数浮点数浮点数( int )( int )( float )( float )单链表如下:每个结点包括数据域和指针域:数据域指针域C 语言描述如下:typedef struct flightnodechar air_num10;/ 航班号char start_time15;/ 起飞时间char end_time15;/ 抵达时间char start_place20;/起飞城市char end_place20; /降落城市int left;/ 空座数float price;/ 票价float price_discount;/ 票价折扣int isFull;

7、/ 航班是否满仓struct flightnode *next;/ 指向下一个结点flightnode;/ 航班结点2 )客户的资料:为了便于插入、删除和修改,其采用单链表存储结构,每个数据元素包括姓名、证件号、航班号、订票数量和订单号五个数据项:姓名证件号航班号订票数量订单号字符串字符串字符串整数(int)整数(int )每个结点包括数据域和指针域:数据域指针域C 语言描述如下:typedef struct passengernode/ 定义客户资料结点char name20;/ 姓名char ID_num20;/ 证件号char flight_num10;/ 航班号int order_nu

8、m;/ 订单号int ticket_num;/ 订票数量struct passengernode *next;/ 指向下一个结点 passengernode;( 3 )客户链表:每个数据元素包括头指针和尾指针两个数据项:每个结点包括两个指针域:头指针域尾指针域C 语言描述如下:typedef struct passengerListpassengernode *head;passengernode *rear;passengerList;2.2 程序模块2.2.1 录入航班信息模块void add_flight(flightnode *&h) 调用 void insert_flight(fli

9、ghtnode *&h,char* flight_num,char* start_place,char* end_place,char* start_time,char* end_time,int left,float price,float price_discount,int isFull) 函数,将新航班结点插入航班链表中。2.2.2 客户订票模块int book(flightnode *&h,passengerList *&PList) 函数调用intinsert_passenger(passengernode *&h,char *name,char *ID_num,char *fli

10、ght_num,int ticket_num,int order_num) 函数,将新客户结点插入客户链表中。2.2.3 客户退票模块void cancel(passengerList *&PList,flightnode *&h) 函数调用intdelete_passenger(passengerList *&PList,flightnode *&h,char *name,char *ID_num) 函数,将相应的顾客结点删除,并修改相应的航班信息。2.2.4 查询航班模块void flight_check(flightnode *h) 调用 void check_all_flight(fl

11、ightnode *h) 函数进行所有航班信息浏览,调用int place_check(flightnode *h,char *start_place,char*end_place) 函数按起飞抵达城市对航班进行查询,调用intflight_num_check(flightnode *h,char *flight_num) 按航班号对航班进行查询。2.2.5 查询订单模块void passenger_check(passengerList *PList) 调用 voidcheck_all_passenger(passengerList *PList) 函数进行所有订单信息浏览,调用intord

12、er_num_check(passengerList *PList,int order_num) 函数按订单号对订单进行查询,调用 int ID_name_check(passengerList *PList,char *name,char *ID_num) 按客户姓名 和证件号对订单进行查询。2.2.6 修改航班模块增加航班时,void modify_flight(flightnode *&h,passengerList *&PList)函数调用void add_flight(flightnode *&h) 函数,将新航班信息结点插入航班链表中。删除航班时,void modify_fligh

13、t(flightnode *&h,passengerList *&PList)函数调用void delete_flight(flightnode *&h,passengerList *&PList)函数将相应的航班信息删除,并删除相应的订单信息。修改航班时间时,void modify_flight(flightnode *&h,passengerList *&PList)函数修改指定航班的起飞抵达时间。2.3 各模块之间的调用关系以及算法设计2.3.1 各模块之间的调用关系信息增加航班修改 航班 起飞 抵达 时间删除航班信息2.3.2 算法设计void init_flight(flightno

14、de *&h) :要建立一个以h 为头结点的空链表,录入航班信息和增加航班后将航班结点插入该链表。void init_passengerList(passengerList *&pList) :建立一个带有头指针和尾指针的空链表 ,存储带有顾客信息的结点。void save_flight(flightnode *h) :保存航班信息到指定数据文件中。void load_flight(flightnode *&h): 从存储航班信息的文件导入航班信息到航班链表中。void save_passenger(passengerList *PList) :保存客户信息到指定数据文件中。void load

15、_passenger(passengerList *&PList) :从存储客户信息的文件导入客户信息到客户链表中。void add_flight(flightnode *&h): 录入航班信息后调用insert_flight 函数增加航班。void insert_flight(flightnode *&h,char* flight_num,char* start_place,char*end_place,char* start_time,char* end_time,int left,float price,float price_discount,int isFull) :在录入航班情况或

16、增加新的航班后,将新的航班结点插入到航线链表中。int book(flightnode *&l,passengerList *&PList)要完成客户订票,将客户结点插入客户链表中,并修改相应的航班信息。void insert_passengerList(flightnode *&h,passengerList *&PList,char*name,char *ID_num,char *flight_num,int ticket_num) :在顾客订票后,将该顾客结点插入到顾客链表中,并修改相应的航班信息。void find_same_flight(flightnode *l,char *fli

17、ght_num) :在客户订票时,当客户输入的航班号对应的航班已满仓时,提供其他可选航班并输出显示。void cancel(passengerList *&PList,flightnode *&h) :完成客户退票,将客户的订单从客户链表中删除,并修改相应的航班信息。int delete_passenger(passengerList *&PList,flightnode *&h,char *name,char*ID_num) :按照要退票的顾客的姓名和证件号查找该顾客结点,进行删除操作。void flight_check(flightnode *h) :选择使用何种方式对航班信息进行查询。v

18、oid check_all_flight(flightnode *l) :浏览所有航班信息。int place_check(flightnode *l,char *start_place,char *end_place) :按照起飞抵达城市查询航班信息。int flight_num_check(flightnode *l,char *flight_num) :按照航班号查询航班信息。void passenger_check(passengerList *PList) :选择使用何种方式对订单信息进行查询。void check_all_passenger(passengerList *PList

19、) :浏览所有订单信息。int order_num_check(passengerList *PList,int order_num)int ID_name_check(passengerList *PList,char *name,char *ID_num) :按客户姓 名和证件号查询订单信息。void modify_flight(flightnode *&h,passengerList *&PList):修改航班信息,包括添加航班信息,删除航班信息,修改航班起飞抵达时间。void delete_flight(flightnode *&h,passengerList *&PList):按照某

20、个航班号删除航班结点。3. 详细设计3.1 录入航班信息模块在主函数中输入“1 ”,调用 void add_flight(flightnode *&h) 函数,此函数将航班指针 *p 指向已存在航班链表*h 的头结点,利用 for(;p-next!=NULL;p=p-next) 使 *p 指向航线链表的最后一个结点,然后让用户输入航班信息,然后调用voidinsert_flight(flightnode *&h,char* flight_num,char* start_place,char*end_place,char* start_time,char* end_time,int left,f

21、loat price,floatprice_discount,int isFull) 函数,用malloc 函数申请一个航班结点,并用指针*q 指向 ,将航班信息赋到新申请的结点中,p-next=q;p=p-next; 该操作将该结点插入航班链表中。流程图如下:3.2 顾客订票模块在主函数中输入“2”,调用 int book(flightnode *&h,passengerList *&PList) 函数完成客户的订票。用航班指针*p 指向已存在航班链表*h 的头结点的下一个结点,请客户输入起飞抵达城市,分别存于start_place 和 end_place 中。调用intplace_chec

22、k(flightnode *l,char *start_place,char *end_place) 函数, 如果函数返回“ 1 ”则请客户输入要订的航班号,如果输入的航班号不存在,输出提示信息,如果航班存在则提示客户输入订的票数、客户的姓名和证件号,调用voidinsert_passengerList(flightnode *&h,passengerList *&PList,char *name,char*ID_num,char *flight_num,int ticket_num) 函数,定义航班指针*p=h-next ,使用 for循环匹配flight_num 和 p-flight_nu

23、m ,找到后,执行p-left=p-left-ticket_num ,修改相应航班的空座数。用malloc 函数申请一个客户结点,并用指针*q 指向,将客户信息和航班号赋到新申请的结点中,PList-rear-next=q;PList-rear=q; 该操作将该结点插入客户链表中。如果该航班已满仓或该航班的空座数不够,输出可供选择的航班,让客户选择,之后调用 void insert_passengerList(flightnode *&h,passengerList *&PList,char*name,char *ID_num,char *flight_num,int ticket_num)

24、函数将客户结点插入客户链表中.接上页:结束3.3 顾客退票模块在主函数中输入“3 ”,调用void cancel(passengerList *&PList,flightnode *&h)函数完成客户的退票。提示客户输入客户的姓名和证件号以及要退的航班号,此函数再调用 int delete_passenger(passengerList *&PList,flightnode *&h,char *name,char*ID_num,char *flight_num) 函数,用客户结点指针*pr 等于已存在客户链表结点Plist 的头指针,相当于将*pr 指向客户链表的头结点,用客户结点指针*p 指

25、向 pr 的下一个结点。使用 while 循环寻找匹配姓名、证件号、航班号的客户结点,找到后定义航班指针*f=h-next ,使用 for 循环找到匹配航班号的航班结点,执行f-left=f-left+p-ticket_num ,修改退票后相应航班结点的空座数,之后执行pr-next=p-next;free(p); 删除要退票的客户订单信息。如果没有找到匹配的客户结点,输出提示信息。开始输入姓名、证件号、航班号,分别存于name、 ID_num 、 flight_num调用deletepassenger函数delete_passenger开始gernode *pr=PList-headenge

26、rnode *p=pr-nextpr-next=p-nextfree(p)pr=pr-next;p=pr-next;返回“ 1 ”返回“ 0”3.4 查询航班模块在主函数中输入“ 4 ”, 调用 void flight_check(flightnode *h) 函数选择使用哪一种查询方式进行查询。提示客户输入查询方式,如客户输入“1 ”,则调用intflight_num_check(flightnode *l,char *flight_num) 函数按航班号对航班进行查询,提示客户输入航班号,存于flight_num 中;如客户输入“2”,则调用intplace_check(flightnod

27、e *l,char *start_place,char *end_place) 函数按起飞抵达城市对航班进行查询,提示客户输入起飞抵达城市,分别存于start_place 和 end_place 中;如客户输入“3 ”,则调用void check_all_flight(flightnode *l) 函数浏览全部航班信息。在 int flight_num_check(flightnode *l,char *flight_num)*p=h ,使用 for 循环匹配flight_num 和 p-flight_num ,找到匹配的航班节点后,输出 该航班的所有信息。函数中,定义的结点,找到匹配的*p=

28、h ,使用 for 循环在 int place_check(flightnode *l,char *start_place,char *end_place)航班指针*p=h ,使用 for 循环寻找匹配start_place 和 start_place航班结点后,输出该航班的所有信息。在 void check_all_flight(flightnode *l) 函数中,定义航班指针flight_num_check 函数的流程图:3.5 查询订单模块在主函数中输入“5”,调用void passenger_check(passengerList *PList) 函数选择使用哪一种查询方式进行查询。

29、提示客户输入查询方式,如客户输入“1 ”,则调用intID_name_check(passengerList *PList,char *name,char *ID_num) 函数按客户的姓名和证件号对订单进行查询,提示客户输入姓名和证件号,分别存于name 和 ID_num 中; 如客户输入 “ 2”, 则调用 int order_num_check(passengerList *PList,int order_num) 函数按订单号对订单进行查询,提示客户输入订单号,存于order_num 中;如客户输入“3”,则调用 void check_all_passenger(passengerLi

30、st *PList) 函数浏览全部订单信息。在 int ID_name_check(passengerList *PList,char *name,char *ID_num) 函数中,定义客户指针*p= PList-head-next , 使用 for 循环寻找匹配name 和 ID_num 的结点, 找到匹配的订单节点后,输出该订单的所有信息。定义客户指在 int order_num_check(passengerList *PList,int order_num)针 *p=PList-head-next , 使用 for 循环寻找匹配order_num 的结点, 找到匹配的订单 结点后,输

31、出该订单的所有信息。在 void check_all_passenger(passengerList *PList) 函数中,定义客户指针for 循环输出所有订单信息。ordernumcheck*p=PList-head-next3.6 修改航班模块在主函数中输入“6”,调用 void modify_flight(flightnode *&h,passengerList*&PList) 函数对航班信息进行修改。提示客户输入修改模式,如客户输入“ 1 ”, 则调用 voidadd_flight(flightnode *&h) 函数添加航班信息;如客户输入“2”,则调用voiddelete_fli

32、ght(flightnode *&h,passengerList *&PList) 函数删除指定的航班信息,提示客户输入航班号,存于flight_num 中;如客户输入“3”,则示客户输入航班号,如果该航班号存在,则提示用户输入修改后的起飞抵达时间。在 void delete_flight(flightnode *&h,passengerList *&PList)函数中,定义航班指针 *pr=h ,定义航班指针p=pr-next ,定义客户指针*qr=PList-head ,定义客户指针q=qr-next 。使用 while 循环寻找匹配航班号的航班结点,找到后执行pr-next=p-next

33、;free(p)删除指定的航班信息;使用 开始while 循环找到匹配航班号的订如果没有找到单结点, 执行qr-next=q-next;fre请客户选择修改模 e式,存于(q), a删除对该航班订票的订单信息。 中匹配的航班结点,输出提示信息。a=1根据 a 的值进行选择a=3a=2调用 add_flight 数添加航班信息输入航班号,存入 flight_num 调用 delete_fli ght 函数删除航班4. 测试与分析4.1 合法数据的测试( 1 ) 编译链接后显示菜单2 ) 输入菜单号“1 ”,开始航班信息的录入3 ) 输入菜单号“2”,进入订票模块4 ) 输入菜单号“3”,进入退票

34、模块5 ) 输入菜单号“4 ”,查询航班信息a. 输入菜单号“1 ”,按航班号查询航班信息b. 输入菜单号“2”,按起飞抵达城市查询航班信息c. 输入菜单号“3”,浏览全部航班信息8 ) 输入菜单号“0”,退出本系统。6 ) 输入菜单号“5”,查询订单信息a. 输入菜单号“1 ”,按客户姓名和证件号查询订单信息b. 输入菜单号“2”,按订单号查询订单信息7 ) 输入菜单号“6”,进入航班修改模块a. 输入菜单号“1 ”,增加航班b. 输入菜单号“2”,删除航班c. 输入菜单号“3”,修改航班时间4.2 非法数据的测试( 1 ) 在主菜单中输入错误号码后,系统自动跳转到主菜单,继续让用户输入。2

35、 ) 选择订票服务后,输入了没有开通航班的城市3 ) 选择订票服务后,输入了系统中没有的航班号4 ) 选择退票服务后,输入了没有订票的客户姓名和证件号5 ) 选择航班查询服务后,输入了没有开通航班的城市6 ) 选择航班查询服务后,输入了系统中不存在的航班号7 ) 选择订单查询服务后,输入了没有订票的客户姓名和证件号8 ) 选择订单查询服务后,输入了系统中不存在的订单号9 ) 选择删除航班服务后,输入了系统中不存在的航班号10 ) 选择修改航班时间服务后,输入了系统中不存在的航班号5. 用户使用说明5.1 运行环境Windows xp ; Microsoft Visual C+ 6.05.2 主

36、要功能飞机订票系统系统功能模块如下:主要功能包括录入航班信息、客户订票、客户退票、查询航班信息、查询订单信息、修改航班信息六个模块;其中查询航班信息模块包括按航班号查询、按起飞抵达城市查询和浏览全部航班信息;其中查询订单信息模块包括按订单号查询、按客户姓名和证件号查询以及浏览全部订单信息;其中修改航班信息模块包括添加航班信息、删除航班信息和修改航班起飞抵达时间。5.3 操作注意事项用户在使用飞机订票系统之前,应注意以下事项:用户在输入数据时,飞机航班号、起飞抵达城市、起飞抵达时间、客户姓名、证件号等为字符串形式;空座数、订票数量、航班是否满仓等为整型(int ) ;票价、票价折扣等为浮点型(f

37、loat ) ;其他形式的输入,请按输入提示进行操作,以免引起不必要的故障。5.4 业务流程输入相应的选择信息,便可进入相应的模块中。( 1 )输入“1 ” ,进入【录入航班信息】模块,输入航班的相关信息,完成航班信息的录入。( 2 )输入“2”,进入【客户订票】模块,输入客户的信息、要订的票数和要订的航班号,完成客户的订票操作。( 3 )输入“3”,进入【客户退票】模块,输入客户的信息、要退的航班号,完成客户的退票操作。( 4)输入“4”,进入【查询航班信息】模块,可以浏览或查询航班的相关信息。( 5 )输入“5”,进入【查询订单信息】模块,可以浏览或查询订单的相关信息。( 6)输入“6”,

38、进入【修改航班信息】模块,可以添加航班信息、删除航班信息和修改航班的起飞抵达时间。6. 总结经过这两周的数据结构课程设计,我收获很大,在实现系统功能的过程中,也遇到很多问题,分工协作,设计修改,编写调试,每一步都渗透着沟通和分析,每一次沟通之后,都会对系统功能有更深层次的理解和阐述,这也促使我们一步步完成了整个系统,并使之可以运行。两周的时间太短暂了,我们无法把全部学到的知识运用到具体的系统实现中,深深感受到数据结构这门课程的重要性,以及它在实际应用中的广泛性。本系统由于种种原因仍然存在需要改进,需要完善的地方,我对于这个系统的认识和对数据结构这门课程的理解已经更加深入了。在今后的学习和工作中

39、,会更加深入地把知识和思想体会更广泛 地应用到其他相关领域。本系统在人性化的方面做得还不够,对于另类的输入错误,还不能很好地应对,这也 体现出本系统不够健壮,会在今后的学习中加以改进和完善;在功能模块方面还可以增加更多相关模块,是系统更加完善。在实现系统的过程中,我感受到自己的知识的薄弱零散,经过这次做系统,我觉得自己的知识得到巩固和整合,知识体系更加系统化。我也深深体会到实践检验真理,只有实践中,才能出真知。我懂得了学习不只是纸上谈兵,更重要的是实践,就比如平常我们在学习中经常会遇到一些问题,看似无关紧要跳过去,不求甚解,在得知答案的时候,总是感觉心领神会,久而久之,对于的知识点就模棱两可,

40、形成知识漏洞。但这次课程设计所要编写的程序很长,涉及的知识点也很多,选择此题目的时候我心里面还底气十足,自认为没什么问题,对于程序的步骤仿佛了然于胸,但在实际操作中才发现并非如此,在编写程序的过程中,我不断地查阅相关资料进行学习,积极地思考该怎样实现系统的每一个功能。通过这次数据结构的课程设计,我巩固和加深对数据结构基本知识的理解,锻炼了综合运用课本知识的能力,自己也真正地完整而系统地设计并编写了一个程序,使得自己的编程能力大为提高。通过对我所选择飞机订票系统的设计和编写,我初步掌握简单软件的分析方法和设计方法,更深的领悟了“纸上得来终觉浅,觉知此事要躬行”的重要意义,第一次体会到了数据结构编

41、程知识在实际生活中的重要性和应用的广泛性。1 谭浩强 C 程序设计(第四版)北京 :清华大学出版社,20062 李春葆 数据结构教程(第二版)北京:清华大学出版社,2007附录:程序源代码#include #include #include #include typedef struct flightnodechar flight_num10; /航班号char start_time10; /起飞时间char end_time10;/抵达时间char start_place20;/ 起飞城市char end_place20;/抵达城市int left;/空座数float price;/ 票价f

42、loat price_discount;/ 票价折扣int isFull;/ 航班是否满仓struct flightnode *next;/ 指向下一个结点flightnode;/ 航班结点typedef struct passengernodechar name20;/姓名char ID_num20;/证件号char flight_num10;/ 航班号int order_num;/订单号int ticket_num; / 订票数量struct passengernode *next;/ 指向下一个结点passengernode;/ 客户结点typedef struct passengerL

43、istpassengernode *head;passengernode *rear;passengerList;void init_flight(flightnode *&h)/ 目的是要建立一个以h 为头结点的空链表,录入航班信息和增加航班后将航班结点插入该链表h=(flightnode *)malloc(sizeof(flightnode);/if(h=NULL) exit(0);h-next=NULL;/ 将头结点h 的指针域置为空void init_passengerList(passengerList *&pList)创建头结点pList=(passengerList *)mall

44、oc(sizeof(passengerList);pList-head=(passengernode *)malloc(sizeof(passengernode);/ pList-rear=pList-head;pList-rear-order_num=0;/ 订单号从0 开始计数pList-head-next=NULL;void save_passenger(passengerList *PList)FILE* fp = fopen(passenger.dat,wb);if(fp=NULL)return;passengernode *temp=PList-head-next;while(te

45、mp!=NULL)fwrite(temp,sizeof(passengernode),1,fp);temp = temp-next;fclose(fp);void load_passenger(passengerList *PList)FILE* fp = fopen(passenger.dat,rb);if(fp=NULL)return;passengernode *q;int n;while(!feof(fp)q=(passengernode *)malloc(sizeof(passengernode);n =fread(q,sizeof(passengernode),1,fp);if(n

46、!=1)break;PList-rear-next=q;PList-rear=q;PList-rear-next=NULL;fclose(fp);void save_flight(flightnode *h)FILE* fp = fopen(flightList.dat,wb);if(fp=NULL)return;flightnode *temp=h-next;while(temp!=NULL)fwrite(temp,sizeof(flightnode),1,fp);temp = temp-next;fclose(fp);void load_flight(flightnode *&h)flig

47、htnode *pt=h;FILE* fp = fopen(flightList.dat,rb);if(fp=NULL)return;flightnode *q;int n;while(!feof(fp)q=(flightnode *)malloc(sizeof(flightnode);n=fread(q,sizeof(flightnode),1,fp);if(n!=1)break;pt-next=q;pt=q;pt-next=NULL;fclose(fp);int find_same_flight(flightnode *h,char *flight_num)flightnode *t=h-

48、next,*p=h-next;int mark=0;printf(%-8s%-12s%-12s%-10s%-10s%-8s%-6s%-10s%-8sn, 航班号 ,起飞城 市 ,抵达城市 ,起飞时间 ,抵达时间,价格 ,折扣 ,是否满仓 ,空座数 );while(t!=NULL & strcmp(t-flight_num,flight_num)!=0) t=t-next;while(p!=NULL)if(strcmp(t-start_place,p-start_place)=0)&(strcmp(t-end_place,p-end_place)= 0)&(strcmp(t-flight_num

49、,p-flight_num)!=0) printf(%-8s%-12s%-12s%-10s%-10s%-8.2f%-6.2f%-10d%-8dn,p-flight_num,p-start_place,p-end_place,p-start_time,p-end_time,p-price,p-price_disco unt,p-isFull,p-left);mark=1; p=p-next;if(mark=0)printf(tt 抱歉,没有可选的航班!n);return 0;return 1;void insert_flight(flightnode *&h,char* flight_num,c

50、har* start_place,char* end_place,char* start_time,char* end_time,int left,float price,float price_discount,int isFull)/ 在录入航班情况或增加新的航班后,将新的航班结点插入到航线链表中flightnode *q;/ 定义 q 为新增加的航班结点的指针的形参flightnode *p=h;q=(flightnode *)malloc(sizeof(flightnode);/ 为 q 结点申请空间strcpy(q-flight_num,flight_num);strcpy(q-st

51、art_place,start_place);strcpy(q-end_place,end_place);strcpy(q-start_time,start_time);strcpy(q-end_time,end_time);q-left=left;q-price=price;q-price_discount=price_discount;q-isFull=isFull;/ 以上是用strcpy 函数将新增加航班的各种信息复制到q 结点中q-next=p-next;/ 将 q 结点的指针域置为空p-next=q;p=p-next;/ 将指针后移void insert_passengerList(flightnode *&h,passengerList *&PList,char *name,char *ID_num,char *flight_num,int ticket_num)/ 客户订票后,将客户结点插入客户链表中,并修改相应的航班信息。flightnode *p=h-next;for(;p!=NULL;p=p-next)if(strcmp(p-flight_num,flight_num)=0)p-left=p-left-ticket_num;if(p-left=0)p-isFull=1;passenger

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论