数据结构课程设计《订票系统航空》报告源代码Word文档下载推荐.docx
- 文档编号:17482006
- 上传时间:2022-12-06
- 格式:DOCX
- 页数:33
- 大小:25.33KB
数据结构课程设计《订票系统航空》报告源代码Word文档下载推荐.docx
《数据结构课程设计《订票系统航空》报告源代码Word文档下载推荐.docx》由会员分享,可在线阅读,更多相关《数据结构课程设计《订票系统航空》报告源代码Word文档下载推荐.docx(33页珍藏版)》请在冰豆网上搜索。
C语言),自行实现一个较为完整地应用系统地设计与开发.通过课程
设计,自己通过系统分析、系统设计、编程调试,写实验报告等环节,进一步掌握应用系统设计地方法和步骤,灵活运用并深刻理解典型数据结构在软件开发中地应用.学会将知识应用于实际地方法,提高分析和解决问题地能力,增加综合能
力.GMsIasNXkA
1.3所选题目地主要工作
这个题目地主要工作是使订票系统可以录入航班情况,查询某个航线地情
况、办理订票、办理退票、修改航班信息、查询订票信息等.TIrRGchYzg
二、需求分析
2.1用户需求分析
用户使用此程序所要完成地工作主要为:
查询所有航线信息、查看已订票客
户信息、查询航线、办理订票业务、办理退票业务.通过此系统可以方便地进行
上述工作.7EqZcWLZNX
每条航线所涉及地信息有:
终点站名、航班号、飞行时间、票价、乘员定额、余票量.
已订票地客户名单信息包括姓名、订票量、舱位等级<
1,2或3).
等候替补地客户名单信息包括姓名、所需票量.
查询航线功能可以根据旅客提出地终点站名输出航班号、飞行时间、票价、乘员定额、余票量.
订票业务功能根据客户提出地要求<
航班号、订票数额)查询该航班票额情况,若尚有余票,则为客户办理订票手续,输出座位号;
若已满员或余票额少于定票额,则需重新询问客户要求.若需要,可登记排队候补购票.lzq7IGf02E
退票业务功能根据客户提供地情况<
航班号、姓名)为客户办理退票手续,然后查询该航班是否有人排队候补,首先询问排在第一地客户,若所退票额能满足他地要求,则为他办理订票手续,否则依次询问其他排队候补地客户.zvpgeqJ1hk
2.2功能需求分析
功能需求分析模块图如图2.2.1功能模块图:
图2.2.1功能模块图
2.3系统需求分析
开发环境:
PC机
WindowsXP系统
使用软件:
编写实验报告:
MicrosoftOfficeWord
画图:
亿图
制作程序:
MicrosoftVisualC++6.0
三、概要设计
3.1各模块地算法设计说明
1.浏览航线信息功能,调用display函数进行输出.流程图如图3.1.1浏览航线信息流程图:
图3.1.1浏览航线信息流程图:
其中display函数地流程图如图3.1.2display函数流程图:
图
3.1.2display
函数流程图
2.浏览已订票客户信息功能
按顺序输出客户信息链表中地信息
.流程图如
图3.1.3
浏览已订票客户信息功能流程图:
NrpoJac3v1
图3.1.3浏览已订票客户信息功能流程图
3.查询航线功能,根据客户提出地终点站名输出航线信息.流程图如图
3.1.4查询航线流程图:
图3.1.4查询航线流程图
4.办理订票业务功能,根据客户提出地航线信息等进行订票.流程图如图
3.1.5办理订票业务功能流程图:
1nowfTG4KI
图3.1.5办理订票业务功能流程图
5.办理退票业务功能,根据客户提出地航线信息等进行退票.流程图如图
3.1.6办理退票业务功能流程图:
fjnFLDa5Zo
图3.1.6办理退票业务功能流程图
6.主函数流程图如图3.1.7主函数流程图:
3.1.7
主函数流程图
3.2存储结构设计说明
typedefstructwat_ros
/*
单链队列存储等候替补地客户信息
*/
{
charname[10]。
/*姓名*/
intreq_amt。
/*订票量*/
structwat_ros*next。
}qnode,*qptr。
typedefstructpqueue
/*等候替补地客户名单
qptrfront。
/*等候替补客户名单域地队头指针
qptrrear。
/*等候替补客户名单域地队尾指针
}linkqueue
。
上述单链队列用来存储排队等候地客户名单,这样可以通过队先进先出地特
点来进行操作.先排队地客户可以先订票成功.tfnNhnE6e5
typedefstructord_ros
乘员名单
intord_amt。
/*客户姓名/*订票量*/
intgrade。
/*舱位等级
structord_ros*next。
}linklist。
上述单链表用来存储乘员地信息,包括姓名、订票量、舱位等级.
structairline
航线信息
charter_name[10]。
/*抵达城市*/
charair_num[10]。
/*航班号*/
chartime[10]。
/*飞机时间*/
charpri[7]。
/*票价*/
inttkt_amt。
/*乘员定额*/
inttkt_sur。
/*余票量*/
linklist*order。
/*乘员名单域,指向乘员名单链表地头指针
linkqueuewait。
/*等候替补地客户名单域,分别指向排队等候名单队头队尾地指针*/
}lineinfo。
这个结构体存储了航线信息,包括抵达城市、航班号、飞行时间、票价、乘员定额、余票量等.
#defineMAXSIZE5
定义航线数量
可修改*/
structairlineair[MAXSIZE]=
初始化航线信息
{"
beijing"
"
1"
1200"
860"
30,30},
shanghai"
2"
1000"
770"
20,20},
london"
3"
1330"
960"
10,10},
harbin"
4"
1700"
760"
50,50},
dalian"
5"
1400"
550"
40,40}
}。
通过修改全局变量MAXSIZE地数值即可更改航线数.在structairline
air[MAXSIZE]中可以修改、增加、删除航线信息
.航线信息内容依次为抵达城
市、航班号、飞行时间、票价、乘员定额、余票量
<
飞行时间1200即12:
00).HbmVN777sL
四、详细设计
1.查看航线信息
编写voidlist(>
函数来查看全部航线信息.其中调用了void
display(structairline*info>
函数,该函数地功能是打印每条航线地基本信
息.这样即可按顺序打印出structairline链表中存储地全部航线信
息.V7l4jRB8Hs
2.查看已订票客户信息
编写voidprtlink(>
函数来查看已订票客户信息.这个函数中需要输入要查询地
航线,通过find(>
函数来寻找这个航线然后输出该航线乘员域地乘员信息.83lcPA59W9
3.查询航线
编写voidsearch(>
函数来实现查询航线地功能.用户输入抵达城市名,该函数会
在航线信息链表中进行查询.如果有该城市,则会输出此航线地信息.mZkklkzaaP4..办理订票业务
编写
voidorder(>
函数来实现订票功能
.首先提示用户输入航班号
然后调用
find(>
函数来查找此航班
如果该航班存在
则会提示用户输入信息并调用
linklist
*insertlink(linklist*head,intamount,charname[],intgrade>
在订票乘员名单域中添加客户信息.如果余票不足,则会提示用户进行排队,如果排队,则会调用提示用户输
入信息并调用linkqueueappendqueue(linkqueueq,charname[],intamount>
在排队等候乘员名单域中添加客户信息.AVktR43bpw
5.办理退票业务
编写voidreturn_tkt(>
函数来实现退票功能.首先提示用户输入航班号,然后调用find(>
函数来查找此航班,如果该航班存在,则会提示用户输入信息,信息正确则会提示退票成功.此时将乘员信息中地该乘员信息删除,然后检查替补乘员链表中地信息,如果其订票量可以得到满足,则会将其插入到订票客户名单链表中,提示他
订票成功.ORjBnOwcEd
6.退出系统
主函数中无限循环输出菜单for(。
>
用户在菜单页面下输入6回车即
exit(0>
即可退出系统.
五、源代码
#include<
stdio.h>
stdlib.h>
string.h>
conio.h>
iostream>
#defineMAXSIZE5/*定义航线数量,可修改*/
/*单链队列存储等候替补地客户信息
/*姓名*/
intreq_amt。
/*订票量*/
structwat_ros*next。
/*等候替补地客户名单
qptrfront。
}linkqueue。
typedefstructord_ros/*乘员名单*/
/*客户姓名
intord_amt。
/*舱位等级*/
structord_ros*next。
charter_name[10]。
charair_num[10]。
/*航班号*/
chartime[10]。
/*飞机时间*/
/*票价*/
/*乘员定额*/
/*余票量*/
/*乘员名单域,指向乘员名单链表地头指针*/
linkqueuewait。
/*等候替补地客户名单域,分别指向排队等候名单队头队尾地
指针*/2MiJTy0dTT
structairline*start。
voiddisplay(structairline*info>
/*打印每条航线地基本信息*/gIiSpiue7A{
printf("
%8s\t%3s\t%s\t\t%4s\t%3d\t%10d\n"
info->
ter_name,info->
air_num,info->
time,info->
pri,info->
tkt_amt,info->
tkt_sur>
。
uEh0U1Yfmh
}
voidlist(>
/*打印全部航线信息
structairline*info。
inti=0。
info=start。
终点站名\t航班号\t飞行时间\t票价\t乘员定额\t余票量\n"
>
while(i<
MAXSIZE>
display(info>
/*调用display函数来输出*/
info++。
i++。
\n\n"
voidsearch(>
/*根据客户提出地终点站名输出航线信息*/
structairline*info,*find(>
/*要抵达地城市名称*/
请输入要抵达城市地名称:
"
scanf("
%s"
name>
if(!
strcmp(name,info->
ter_name>
/*有该站名strcmp则返回,if(!
0>
即
break*/IAg9qLsgBX
break。
if(i>
=MAXSIZE>
/*没有匹配地航线*/
对不起,没有这条航线!
\n"
else
/*调用display函数输出航线信息*/
structairline*find(>
/*根据系统提出地航班号查询并以指针形式返回*/WwghWvVhPE
charnumber[10]。
/*查询地航班号*/
请输入航班号:
number>
strcmp(number,info->
air_num>
/*有匹配航班*/{
returninfo。
}/*无匹配航班*/
returnNULL。
voidprtlink(>
/*打印订票乘员名单域地客户名单信息*/{
linklist*p。
info=find(>
p=info->
order。
if(p!
=NULL>
/*按顺序输出客户信息链表*/
客户姓名订票数额舱位等级\n"
while(p>
%s\t\t%d\t%d\n"
p->
name,p->
ord_amt,p->
grade>
asfpsfpi4kp=p->
next。
/*没有人订这个航班*/
该航线没有客户信息
!
linklist*insertlink(linklist*head,intamount,charname[],intgrade>
/*增加订票乘员名单域
地客户信息*/ooeyYZTjj1
linklist*p1,*new1。
p1=head。
new1=(linklist*>
malloc(sizeof(linklist>
new1>
/*存储空间不足
\nOutofmemory!
strcpy(new1->
name,name>
new1->
ord_amt=amount。
grade=grade。
next=NULL。
if(head==NULL>
/*若原订票客户信息为空*/
head=new1。
next=p1。
returnhead。
linkqueueappendqueue(linkqueueq,charname[],intamount>
/*增加排队等候地客户名单
域*/BkeGuInkxI
qptrnew1。
new1=(qptr>
malloc(sizeof(qnode>
req_amt=amount。
if(q.front==NULL>
/*若原排队等候客户名单域为空*/
q.front=new1。
q.rear->
next=new1。
q.rear=new1。
returnq。
/*办理订票业务
intamount,grade。
/*订票数量,舱位等级*/
/*要订地航班号
(info=find(>
根据客户提供地航班号进行查询
如为空,退出该模块
*/PgdO0sRlMo
return。
请输入您需要地票数
:
%d"
&
amount>
if(amount>
info->
tkt_amt>
若客户订票额超过乘员定票总额
退出
*/3cdXwckm15
\n对不起,您输入票数已经超过乘员定额!
if(amount<
=info->
/*若客户订票额末超过余票量,订票成功并等记
信息*/h8c52WOngM
inti。
请输入您地姓名:
请输入您需要地舱位等级(1,2或>
order=insertlink(info->
order,amount,name,grade>
/*在订票乘员名
单域中添加客户信息*/v4bdyGious
for(i=0。
i<
amount。
i++>
/*依次输出该订票客户地座位号*/
%s地座位号是:
%d\n"
name,info->
tkt_amt-info-
tkt_sur+i+1>
J0bm4qMpJ9
tkt_sur-=amount。
/*该航线地余票量应减掉该客户地订票量
*/XVauA9grYP
\n祝您乘坐愉快!
else/*若满员或余票额少于订票额,询问客户是否需要进行排队等候*/
charr。
\n没有这么多票了,您需要排队等候吗?
(Y/N>
r=getch(>
%c"
r>
if(r=='
Y'
||r=='
y'
\n请输入您地姓名:
wait=appendqueue(info->
wait,name,amount>
/*在排队等候
乘员名单域中添加客户信息*/bR9C6TJscw
\n注册排队成功!
\n欢迎您再次订购!
\n"
voidreturn_tkt(>
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 订票系统航空 数据结构 课程设计 订票 系统 航空 报告 源代码