机票销售系统课程设计报告附心得.docx
- 文档编号:18594999
- 上传时间:2023-08-20
- 格式:DOCX
- 页数:29
- 大小:282.90KB
机票销售系统课程设计报告附心得.docx
《机票销售系统课程设计报告附心得.docx》由会员分享,可在线阅读,更多相关《机票销售系统课程设计报告附心得.docx(29页珍藏版)》请在冰点文库上搜索。
机票销售系统课程设计报告附心得
中南大学
信息科学与工程学院
数据结构课程
设计报告
课题:
专业班级:
学号:
姓名:
指导老师:
完成时间:
一、设计综述
1.设计题目
航空客运订票系统
2.问题描述
每条航线所涉及的信息有:
终点站名、航班号、飞机号、飞机周日(星期几)、乘员定额、余票量、订定票的客户名单(包括姓名、订票量、舱位等级1,2或3)以及等候替补的客户名单(包括姓名、所需数量)。
3.需求分析
(1)查询航线:
根据客户提出的终点站名输出如下信息:
航班号、飞机号、星期几飞行,最近一天航班的日期和余票额;
(2)承办订票业务:
根据客户提出的要求(航班号、订票数额)查询该航班票额情况,若有余票,则为客户办理订票手续,输出座位号;若已满员或余票少余订票额,则需重新询问客户要求。
若需要,可登记排队候补;
(3)承办退票业务:
根据客户提出的情况(日期、航班号),为客户办理退票手续,然后查询该航班是否有人排队候补,首先询问排在第一的客户,若所退票额能满足他的要求,则为他办理订票手续,否则依次询问其它排队候补的客户。
实现提示:
两个客户名单可分别由线性表和队列实现。
为查找方便,已订票客户的线性表应按客户姓名有序,并且,为了插入和删除方便,应以链表作为存储结构。
由于预约人数无法预计,队列也应以链表作为存储结构。
4.完成目标
通过对课程设计课题的研究,依靠自己的理解与学习,进行分析,设计,调试,记录等过程,深入了解数据结构(C语言)的知识与实践操作,将两者相互结合,融会贯通。
二、程序设计
1.概要设计
1.1第一个结构体定义了订票客户passenger所需的全部变量;
typedefstructpassenger
{
charname[10];/*姓名*/
intID[20];//身份证号
intpassword;//密码
inttickets;/*订票量*/
structpassenger*next;
}qnode,*qptr;
1.2第二个结构体用于创建候补客户的存储用循环链表;
typedefstructpqueue
{
qptrfront;
qptrrear;
}linkqueue;
1.3第三个结构图定义了候补客户passenger_wait所需的全部变量;
typedefstructpassenger_wait
{
charname[10];/*客户姓名*/
intID[20];//身份证号
inttickets_wait;/*订票量*/
chargrade;/*舱位等级*/
structpassenger_wait*next;
}linklist;
1.4第四个结构体则定义了每趟航班所需的基本数据,这里可以初始化,但考
虑到这是订票系统,于是没有添加新增航班功能。
structairline
{
charter_name[10];/*终点站名*/
charair_num[10];/*航班号*/
charplane_num[10];/*飞机号*/
charday[7];/*飞行周日(星期几)*/
inttkt_amt;/*乘员定额*/
inttkt_sur;/*余票量*/
linklist*order;/*乘员名单域,指向乘员名单链表的头指针*/
linkqueuewait;/*等候替补的客户名单域*/
}lineinfo;
2.订票系统架构:
3.程序详细设计
本程序包含:
1.主函数2.主菜单函数3.航班信息查询函数(目的地查询函数、航班编号查询函数、航班时间查询函数)4.机票信息查询函数(顾客姓名查询、机票编号查询函数、航班编号查询)5.票卖出函数6.退票函数7.航班信息修改函数8.航班、机票信息文件判断建立函数9.航班、机票信息文件保存函数。
3.1主函数(voidmain())
主函数主要是调用其他函数,并把建立的链表头指针附给主菜单函数。
首先调用航班、机票信息文件判断建立函数。
它首先分别判断在是否存在航班信息文件、机票信息文件。
如果不存在,分别生成文件(航班信息文件设为"d:
\\a.dat",机票信息文件设为"d:
\\b.dat"),生成的文件中都已有初始数据。
详细数据见3.1初始航班、机票文件内容。
如果存在,则不再生成文件,而且不会变动已有的文件。
然后它会分别读文件,分别生成航班信息的链表和机票信息链表,并将链表头返回到主函数的变量中。
然后主函数调用主菜单函数,同时将两个链表头赋给主菜单函数。
main
航班信息文件判断生成函数
机票信息文件判断生成函数
主菜单函数
主函数流程图如下:
3.2主菜单函数(voidmenu(structflight*f,structticket*t))
主菜单函数是供用户选择下一步操作(函数),并把下一步需要的两个链表的头赋给该函数。
主菜单流程图如下:
航班信息查询
主菜单函数
选择输入i
i>1且i<7
switch(i)
机票信息查询
买票
退票
航班信息修改
退出
0
非0
i=5
i=2
i=3
i=4
i=1
i=6
输出选择界面
打印“输入有误,重新输入”
3.3航班信息查询函数
(voidsearch(structflight*f,structticket*t))
航班信息查询函数是供用户选择输入什么样查询的航班信息来查询航班。
同时把链表头赋予调用的函数。
航班信息查询函数流程图:
航班信息查
函数
选择输入i
i>1且i<5
switch(i)
目的地查询
航班编号查询
起飞时间查询
返回主菜单
0
非0
i=1
i=2
i=3
i=4
输出选择界面
打印“输入有误,重新输入
在航班信息查询函数中会调用三个查询用的函数,分别是目的地查询函数(voiddestsearch(structflight*f,structticket*t))、航班编号查询函数(voidfNOsearch(structflight*f,structticket*t))、航班起飞时间查询函数(voidtimesearch(structflight*f,structticket*t))。
3.4目的地查询函数流程图
(p是structflight型指针,赋初值为航班信息链表头):
3.5机票信息查询函数
(voidlist(structflight*f,structticket*t))
机票信息查询函数和航班信息查询函数有很高的类似性,是供用户选择输入什么样查询的机票信息来查询航班。
同时把机票链表头赋予调用的函数。
机票信息查
函数
选择输入i
i>1且i<5
switch(i)
顾客姓名查询
机票编号查询
航班编号查询
返回主菜单
0
非0
i=1
i=2
i=3
i=4
输出选择界面
打印“输入有误,重新输入”
机票信息查询函数流程图:
顾客姓名查询函数
p!
=NULL
p=p->next
p中机票的姓名比较
0
0
非0
非0
输入查询的姓名
打印p中机票信息
打印“输入有误,重新输入”
选择输入i
i>-1且i<5
switch(i)
保存链表退出
姓名查询函数
机票信息函数
主菜单函数
i=0
i=1
i=2
i=3
退票函数
i=4
3.6顾客姓名查询函数流程图:
(p是structticket型的指针,赋初值为机票信息链表头)
3.7卖票函数(voidbook(structflight*f,structticket*t))
卖票函数供用户卖出飞机票,并录入顾客信息,最后将信息写入文件。
由于在本程序中能够唯一确定一个航班的变量只有航班编号。
所以在卖票时候,要求输入要卖出的航班编号。
程序会遍历链表,搜索是否有该航班,有航班并且确认购买后,输入顾客信息,同时程序会自动在该航班剩余票数上减去1。
然后程序会把数据写入文件中。
完成卖票后,程序会回到主菜单。
卖票函数流程图(pr是structflight型指针,赋初值为航班信息链表头)
卖票函数
输入航班编号
pr!
=NULLL
pr=pr->next
pr中航班编号与输入编号的比较
0
0
非0
非0
打印pr中航班信息
输入i选择
switch(i)
输入顾客信息
相关航班信息赋予机票中
生成机票编号
主菜单函数
航班剩余票数减1
储存两链表信息
1
2
3.8退票函数voidreturn_tkt(structflight*f,structticket*t)
退票函数是完成退票功能。
由于在程序中唯一能够确定一张机票的变量为机票编号,所以在退票时候,要求输入要退的机票编号。
程序遍历机票链表,搜索该机票,如果不存在,则输出“不存在该机票”;如果存在机票,打印机票信息,在确认退票后会删除该条机票信息,并且在该票对应的航班的剩余票数上加1。
然后程序将两链表写入文件中。
完成退票后,程序返回主菜单。
退票函数流程图(p是structticket型指针,赋初值为机票信息链表头)
退票函数
输入机票编号
p!
=NULLL
p=p->next
p中航班编号与输入编号的比较
0
0
非0
非0
打印p中机票信息
输入i选择
switch(i)
删除该机票
主菜单函数
航班剩余票数加1
储存两链表信息
1
2
4.源代码清单
//王骞通信1103班0909111423航空售票系统
#include
#include
#include
#defineMAXSIZE10
typedefstructpassenger_wait
{charname[10];/*姓名*/
charID[20];//身份证号
charphone[11];//电话
inttickets_wait;/*订票量*/
structpassenger_wait*next;
}qnode,*qptr;
typedefstructpqueue
{qptrfront;/*等候替补客户名单域的头指针*/
qptrrear;/*等候替补客户名单域的属指针*/
}linkqueue;
typedefstructpassenger_ready
{charname[10];/*客户姓名*/
charID[20];//身份证号
charphone[11];//电话
inttickets_ready;/*订票量*/
chargrade;/*舱位等级*/
structpassenger_ready*next;
}linklist;
structairline
{charter_name[10];/*终点站名*/
charair_num[10];/*航班号*/
charplane_num[10];/*飞机号*/
charday[7];/*飞行周日(星期几)*/
inttickets_total;/*乘员定额*/
inttickets_left;/*余票量*/
linklist*book;/*乘员名单域,指向乘员名单链表的头指针*/
linkqueuewait;/*等候替补的客户名单域,分别指向排队等候名单队头队尾的指针*/
}lineinfo;
structairline*start;
//函数申明
voidsearch();
voiddisplay();
voidprtlink();
voidbook();
voidreturn_tkt();
intmenu_select()
/*菜单界面*/
{
intc;
chars[20];
system("color1B");
system("cls");
puts("\t**********************航空售票系统************************\n");
puts("\t\t查询:
1.浏览航线信息");
puts("\t\t2.浏览已订票客户信息");
puts("\t\t3.查询航线\n\n");
puts("\t\t订购:
4.办理订票业务");
puts("\t\t5.办理退票业务\n\n");
puts("\t\t退出:
6.退出系统");
puts("\t**********************************************************");
printf("\t请从1-6中选择操作:
");
do{
scanf("%s",s);
c=atoi(s);
}while(c<0||c>7);
returnc;
}
main()
{structairlineair[MAXSIZE]=
{
{"北京","1","BJ7001","周日",70,60},
{"广州","2","GZ5002","周五",60,50},
{"香港","3","HK4003","周四",100,77},
{"重庆","4","CQ3004","周三",90,68},
{"乌鲁木齐","5","WL1005","周一",50,29},
{"昆明","6","KM6006","周六",80,71},
{"遵义","7","GY3007","周三",50,38},
{"长沙","8","CS7008","周日",40,24},
{"台北","9","TP2009","周二",30,17},
{"杭州","10","HZ5010","周五",60,25},
};/*初始化航线信息*/
/*clrscr();*/
start=air;
for(;;){
switch(menu_select()){
case1:
list();break;
case2:
prtlink();break;
case3:
search();break;
case4:
book();break;
case5:
return_tkt();break;
case6:
system("cls");printf("\n\t\t\t欢迎再次使用,再见!
\n");exit(0);
}
printf("\n\n\t\t\t按任意键返回主菜单!
\n");
getch();
system("cls");
}
}
voiddisplay(structairline*info)
/*打印每条航线的基本信息*/
{printf("%8s\t%3s\t%s\t%4s\t\t%3d\t%10d\n",info->ter_name,info->air_num,info->plane_num,info->day,info->tickets_total,info->tickets_left);
}
voidlist()/*打印全部航线信息*/
{
system("cls");
structairline*info;
inti=0;
info=start;
printf("\n\n\n\n终点站名\t航班号\t飞机号\t飞行周次\t乘员定额\t余票量\n");
while(i display(info); info++; i++; } printf("\n\n"); } voidsearch() /*根据客户提出的终点站名输出航线信息*/ { system("cls"); structairline*info,*find(); charname[10]; inti=0; info=start; printf("\n\t\t请输入终点站名: "); scanf("%s",name); while(i if(! strcmp(name,info->ter_name))break; info++; i++; } if(i>=MAXSIZE) {system("cls"); printf("\n\n\n\n\n\t\t\t对不起,该航线未找到! \n");} else{ printf("\n\n\n\n终点站名\t航班号\t飞机号\t飞行周日\t乘员定额\t余票量\n"); display(info); } } structairline*find() /*根据系统提出的航班号查询并以指针形式返回*/ {structairline*info; charnumber[10]; inti=0; info=start; printf("\n\t\t请输入航班号: "); scanf("%s",number); while(i if(! strcmp(number,info->air_num))returninfo; info++; i++; } system("cls"); printf("\n\n\n\n\n\n\t\t\t对不起,该航线未找到! \n"); returnNULL; } voidprtlink() /*打印订票乘员名单域的客户名单信息*/ { system("cls"); linklist*p; structairline*info; info=find(); p=info->book; if(p! =NULL){ printf("\n\n\n\n\t\t客户姓名订票数额舱位等级\n"); while(p){ printf("\t\t%s\t\t%d\t%d\n",p->name,p->tickets_ready,p->grade); p=p->next; } } else printf("\n\t\t\t该航线没有客户信息! \n"); } linkqueueappendqueue(linkqueueq,charname[],intamount) /*增加排队等候的客户名单域*/ {qptrnew; new=(qptr)malloc(sizeof(qnode)); strcpy(new->name,name); new->tickets_wait=amount; new->next=NULL; if(q.front==NULL)/*若原排队等候客户名单域为空*/ q.front=new; else q.rear->next=new; q.rear=new; returnq; } linklist*insertlink(linklist*head,intamount,charname[],intgrade) /*增加订票乘员名单域的客户信息*/ {linklist*p1,*new; p1=head; new=(linklist*)malloc(sizeof(linklist)); if(! new){printf("\nOutofmemory! ! \n");returnNULL;} strcpy(new->name,name); new->tickets_ready=amount; new->grade=grade; new->next=NULL; if(head==NULL)/*若原无订票客户信息*/ {head=new;new->next=NULL;} else head=new; new->next=p1; returnhead; } voidbook() /*办理订票业务*/ {system("cls"); structairline*info; intamount,grade; charname[10]; charID[20]; charphone[20]; info=start; if(! (info=find()))return;/*根据客户提供的航班号进行查询,如为空,退出该模块*/ printf("\t\t请输入你订票所需要的数量: "); scanf("%d",&amount); if(amount>info->tickets_total)/*若客户订票额超过乘员定票总额,退出*/ { printf("\n\t\t对不起,您输入的票的数量已经超过乘员定额! \n"); return; } if(amount<=info->tickets_left)/*若客户订票额末超过余票量,订票成功并等记信息*/ { inti; printf("\t\t请输入订票客户的姓名: "); scanf("%s",name); printf("\t\t请输入%s身份证号(18位): ",name); scanf("%s",ID); printf("\t\t请为%s的联系电话: ",name); scanf("%s",phone); printf("\t\t请输入%s的舱位等级(1、2或3): ",name); scanf("%d",&grade); info->book=insertlink(info->book,amount,name,grade);/*在订票乘员名单域中添加客户信息*/ for(i=0;i printf("\n\t\t\t%s的座位号是: %d",name,info->tickets_total-info->tickets_left+i+1); info->tickets_left-=amount;/*该航线的余票量应减掉该客户的订票量*/ printf("\n\n\n\t\t\t订票成功,祝您乘坐愉快! \n"); } else/*若满员或余票额少于订票额,询问客户是否需要进行排队等候*/ {charr; printf("\t\t已经没有更多的票,您需要排队等候吗? (Y/N)"); r=getch(); printf("%c",r); if(r=='Y'||r=='y') {printf("\n\t\t请输入您的姓名(排队订票客户): "); scanf("%s",name); printf("\n\t\t请输入您的手机号: "); scanf("%s",phone); info->wait=appendqueue(info->wait,name,amount);/*在排队等候乘员名单域中添加客户信息*/ system("cls"); printf("\n\n\n\n\
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 机票 销售 系统 课程设计 报告 心得