1、 课 程 设 计 任 务 书 设计题目 飞机订票系统 学生姓名 所在院部 计算机科学与信息工程学院 专业、班级 设计要求: 设计一个飞机订票系统,具体要求如下: 1. 航班信息(包括航班号,起点站,终点站,机票数等) 2. 航班信息浏览 3. 按航班号排序 4. 查询航线:按航班号查询 5. 承办订票和退票业务 7. 保存到文件 8. 退出 学生应完成的工作: 1. 学生应认真学习参考程序,理解每个文件、每个函数以及各个变量的作用和意义。在此基础上进
2、一步改进程序,最后正确地运行程序。 2. 对程序进行测试,设计详细的测试计划,然后根据测试计划设计测试用例,对程序进行测试。测试时应注意对各种边缘情况进行测试。 3. 完成课程设计报告。 参考文献: 1. 梁旭等 C程序设计课程设计 电子工业出版社 2011 2. 谭浩强 C程序设计(第四版) 清华大学出版社2010 工作计划: 1. 小组审题,查阅资料,进行设计前的必要资料准备(3天)。 2. 把程序完整运行出来(4天)。 3. 增加改进程序(3天)。 4. 写课程设计报告(3天)。 5. 提交课程设计报告及答辩(1天) 任务下达日
3、期:2013 年 6 月 10 日 任务完成日期:2013 年 6 月 23 日 指导教师(签名): 学生(签名): 目 录 1 前言 1 2 需求分析 1 2.1要求 1 2.2任务 1 2.3运行环境 1 2.4开发工具 1 3 概要设计 1 3.1系统流程图 2 3.2查询函数流程图 2 4 详细设计 2 5 改进或增加功能模块说明 4 6 程序测试 4 7 课程设计总结 5 8 参考文献 5 9 致 谢 5 10 源程序 5
4、 飞机订票系统 1 前言 编写一个程序来完成航班订票。通过程序来完成航班信息录入功能(航班信息用文件保存) ,其中包括航班号、起始站、重点站、机票数等;航班信息浏览功能;按航班号排序;查询航线:按航班号查询;承办订票和退票业务。 2 需求分析 2.1要求 (1)用C语言实现程序设计; (2)利用结构体、共用体进行相关信息处理; (3)画出查询模块的流程图; (4)系统的各个功能模块要求用函数的形式实现; (5)界面友好(良好的人机互交),程序要有注释。 2.2任务 (1)定义一个结构体类型数组,包括航班号,起点站,终点站,机票数等; (2)输入航班号进行查询;
5、 (3)画出部分模块的流程图; (4)编写代码; (5)程序分析与调试。 2.3运行环境 (1)WINDOWS2000/XP系统 (2)C++6.0编译环境 2.4开发工具 C语言 3 概要设计 3.1系统流程图 飞机 订票 系统 系统 初始化 增加 航班 信息 航班 信息 浏览 航班 排序 订票 业务 退票 业务 建立 新数据 文件 从已有的数据文件读取 按航班号从小到大排序 按航班号从大到小排序 查找 航班 信息 按 航班号查找 退出并保存
6、 3.2查询函数流程图 数据文件 是否存在 输入航班信息并建立新数据文件保存下来 从已有的数据文件读取已有的航班信息 Y 初始化 结束 N 4 详细设计 在程序的开头部分定义了结构替类型,用来存放按钮信息 通过这些为形成整个界面提供了大的前提。 struct airline *start; struct airline air[MAXSIZE]={ {"beijing", "1", "B8571", "SUN", 3, 1}, {"shanghai"
7、"2","S1002","MON",2,5}, {"london","3","L1003","FRI",1,3} };; void display(struct airline *info) { printf("%8s\t%3s\t%s\t%4s\t\%d\t\%d\t\n",info->ter_name,info->air_num,info->plane_num,info->date,info->tkt_amt,info->tkt_sur); } /* 浏览航线信息函数 */ void list() { str
8、uct airline *info; int i = 0; info = start; printf("终点站名\t航班号\t飞机号\t飞行日期" "乘员定额" "余票量\n"); while(i < MAXSIZE){ display(info); info++; i++; } printf("\n\n"); } void search() { struct airline *info,*find(); char name[10]; int i=0; info=sta
9、rt;
printf("请输入终点站名:");
scanf("%s",name);
while(i
10、
char number[10];
int i=0;
info=start;
printf("请输入航班号:");
scanf("%s",number);
while(i
11、 linklist *p; struct airline *info; info=find(); p=info->order; if(p!=NULL){ printf("客户姓名 订票数额 舱位等级\n"); while(p){ printf("%s\t\t%d\t%d\n",p->name,p->ord_amt,p->grade); p=p->next; } } else printf("该航线没有客户信息!!\n"); } linklist
12、insertlink(linklist *head,int amount,char name[],int grade) { linklist *p1,*new1; p1=head; new1=(linklist *)malloc(sizeof(linklist)); if(!new1) {printf("\nOut of memory!!\n");return NULL;} strcpy(new1->name,name); new1->ord_amt=amount; new1->grade=grade; new1->next=NULL; if(head==NULL)
13、{head=new1;new1->next=NULL;} else head=new1; new1->next=p1; return head; } linkqueue appendqueue(linkqueue q,char name[],int amount) { qptr new1; new1=(qptr)malloc(sizeof(qnode)); strcpy(new1->name,name); new1->req_amt=amount; new1->next=NULL; if(q.front==NULL) q.front=new1; else
14、q.rear->next=new1; q.rear=new1; return q; } void order() { struct airline *info; int amount,grade; char name[10]; info=start; if(!(info=find())) return; printf("请输入你订票所需要的数量:"); scanf("%d",&amount); if(amount>info->tkt_amt) { printf("\n对不起,您输入的票的数量已经超过乘员定额!"); return; } if(amount
15、<=info->tkt_sur)
{
int i;
printf("请输入您的姓名(订票客户):");
scanf("%s",name);
printf("请输入%s票的舱位等级:",name);
scanf("%d",&grade);
info->order=insertlink(info->order,amount,name,grade);
for(i=0;i
16、n祝您乘坐愉快!\n"); } else { char r; printf("\n已经没有更多的票,您需要排队等候吗?(Y/N)"); //r=getch(); //printf("%c",r); scanf ( "回车继续等待%c", &r ); if(r=='Y'||r=='y') { printf("\n请输入您的姓名(排队订票客户):"); scanf("%s",name); info->wait=appendqueue(info->wait,name,amount); printf("\n注册成功!\n"); } else printf("\n欢迎
17、您下次再次订购!\n"); } } void return_tkt() { struct airline *info; qnode *t,*back,*f,*r; int grade; linklist *p1,*p2,*head; char cusname[10]; if(!(info=find())) return; head=info->order; p1=head; printf("请输入你的姓名(退票客户):"); scanf("%s",cusname); while(p1!=NULL) { if(!strcmp(cusname,p1->name
18、)) break; p2=p1;p1=p1->next; } if(p1==NULL){ printf("对不起,你没有订过票!\n");return;} else { if(p1==head) head=p1->next; else p2->next=p1->next; info->tkt_sur+=p1->ord_amt; grade=p1->grade; printf("%s成功退票!\n",p1->name); free(p1); } info->order=head; f=(info->wait).front; r=(info->wait).rear
19、
t=f;
while(t)
{
if((info->tkt_sur = info->wait.front->req_amt))
{
int i;
info->wait.front=t->next;
printf("%s订票成功!\n",t->name);
for(i=0;i
20、e,grade);
free(t);
break;
}
back=t;t=t->next;
if((info->tkt_sur)>=(t->req_amt)&&t!=NULL)
{ int i;
back->next=t->next;
printf("%s订票成功!\n",t->name);
for(i=0;i
21、nfo->order,t->req_amt,t->name,grade);
free(t);break;
}
if(f==r) break;
}
}
void sort_tkt()
{
int j;
struct airline t,*info,*p,*q;
p=info=air;
for(p=info;(p+1)->tkt_sur;p++)
for(q=p+1;q->tkt_sur;q++)
{
if(p->tkt_sur
22、行日期\t乘员定额\t余票量\n");
for(j=0;j 23、\n");
printf(" ** 3.查询航线 **\n");
printf(" ** 4.办理订票业务 **\n");
printf(" ** 5.办理退票业务 **\n");
printf(" ** 6.查看剩余票数并排序 **\n");
printf(" ** 0.退出系统 **\n");
printf(" *******************************************\n");
do
{
printf("请选择:");
scanf("%s",s);
c = atoi 24、s); /* atoi将字符串转换为整型 */
}while(c < 0||c > 7);
return c;
}
int main()
{
start = air;
for(;;)
{
switch(menu_select())
{
case 1:list();break;
case 2:prtlink();break;
case 3:search();break;
case 4:order();break;
25、 case 5:return_tkt();break;
case 6:sort_tkt();break;
case 0:printf("\n欢迎使用本系统,再见!\n");exit(0);
}
printf("\nPress any key to continue!\n");
getchar();
}
return 0;
}
通过调用上面定义的函数实现了飞机订票整个功能。
5 改进或增加功能模块说明
6 程序测试
(1).测试系统能否正确显示菜单选项
执行程序后,显 26、示本系统的菜单选项界面,如图6-1所示。
图6-1飞机订票系统主界面
(2).测试系统能否正确显示机票信息
输入如下数据:
终点站名 航班号 飞机号 飞行日期 成员定额 余票量
Beijing 1 B8571 SUN 3 1
Shanghai 2 S1002 MON 2 5
London 3 L1003 FRI 1 3
27、
进入主菜单界面后,输入数字1进入浏览航线信息,根据提示输入你要进行的操作的序号,就能完成你要进行的操作。
图6-2 输入浏览航线信息界面
7 课程设计总结
本程序在刚开始调试时有许多错误,但在我的努力及同学的帮助下都被一一克服,现在在操作本程序时,可根据提示运行本程序,得到结果。
8 参考文献
[1]张福祥. C语言程序设计[M]. 辽宁大学出版社,2008.1
[2] 张福祥,王萌.C语言程序设计习题解答与实验实训[M].沈阳:辽宁大学出版社,2008.
[3] 牛莉,刘远军等.计算机等级考试辅导教程[M].北京:中国铁道出版社,2008.
9 致 谢
13






