版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、河南城建学院课程设计报告书专 业:计算机科学与技术 课程设计名称:数据结构课程设计题 目:飞机航班订票系统班 级:xxx学号:x姓名:xx同 组 人 员:x指 导 老 师:x完 成 时 间:2012-2-17 摘要随着时代的进步社会分工的不断细化,各个行业联系的不断密切,人们出行越来越多,出行的方式也是百花齐放,作为空中重要的交通工具,飞机航空系统也在不断地得到优化,其中重要的一项就是飞机航空订票系统,因此好的订票系统关系着人们的日常出行方便与否,设计并编制出符合人们需要的航空订票系统是一项繁重而艰巨的任务,需要我们认真去完成。本文采用C作为前台开发工具,VC6.0作为程序代码的实现,旨在实现
2、对现有飞机订票系统中遇到的各种情况进行良好的改进,是作为嵌入式系统应用于机场的良好软件。关键词:C,VC 6.0,飞机订票系统目录目录3第一章开发环境和开发工具41.1C语言简介41.2 开发背景41.3 开发环境4第二章 算法思想52.1 系统需求分析52.2 系统总体设计52.2.1 系统设计目标52.2.2 开发设计思想52.2.3 系统功能模块设计62.3 算法思想描述7第三章算法实现.113.1 数据结构113.2 程序模块113.3 各模块之间的调用关系123.4 源程序代码12第四章测试与分析214.1 测试数据选择21 4.2 测试结果分析22总 结22心得体会22参考文献23
3、第一章 开发环境和开发工具1.1 C/C+语言介绍1.2 开发背景随着科学技术的不断发展,计算机科学日渐成熟,其强大功能已为人们所深刻认识,它己进入人类社会的各个领域并发挥着越来越重要的作用。采用计算机进行信息化管理已成为衡量各个国家科学化和现代化的重要标志,而交通方式的全面自动化、信息化则是其中重要的组成部分,在很大程度上影响着企业的经济效益和社会效益。因此,本文所研究的航空订票系统具有一定的使用价值和现实意义。1.3 开发环境 本文所采用的开发环境主要是基于VC6.0和基于面向对象程序设计的c+。VC是个平台开工具。该软件使用TC2为内核,提供WINDOWS平台的开发界面,因此也就支持WI
4、NDOWS平台下的功能,例如剪切、复制、粘贴和查找替换等。而且在功能上也有它的独特特色例如语法加亮、C内嵌汇编、自定义扩展库的支持等。第二章 算法思想2.1 系统需求分析随着经济全球化的推进以及企业激烈的竞争,各大机场订票系统已经越来越不能适应人们日常出行的局面,所以我们现在需要一个检索迅速、查找方便、易修改功能齐全方便的系统来适应我们的需求。问题的提出:为了减少人工工作量,提高工作效率,使机场管理员的工作更加有效的进行。2.2系统总体设计2.21 系统设计目标本文研究开发的航空订票系统用于完成航空订票工作,有以下三个方面的目标:【1】 支持航空管理公司更加便捷的管理【2】 支持航空公司高效率
5、的满足人们空行需求,包括与班机有关的订票,退票,查询等功能。【3】支持航空公司随时增加或者是删除航班信息 2.22 开发设计思想基于以上系统设计目标,本文在开发人事管理信息系统时遵循了以下开发设计思想:采用现有的软硬件环境及先进的管理系统开发方案,从而达到充分利用现有资源,提高系统开发水平和应用效果的目的。尽量达到操作过程中的直观、方便、实用、安全等要求。系统采用模块化程序设计方法,既便于系统功能的各种组合和修改,又便于未参与开发的技术维护人员补充、维护。系统应具备数据库维护功能,及时根据用户需求进行数据的添加、删除、修改、等操作。2.23 系统功能模块设计本系统分为六个模块:增加航班模块、浏
6、览航班模块、查找航班模块、航班排序模块、订票模块、退票模块。得到如图所示系统功能模块图。飞机航班订票系统增加航班信息浏览航班信息航班排序模块退票系统增加机票保存查找函数排序函数查找函数减少机票数目查找函数增加机票数目查找航班信息订票系统输出函数图2-1 系统功能模块图2.3 算法思想描述【1】系统启动时通过输入航班信息来增加乘客的选择范围【2】当选择功能1时,进入增加航班模块【3】当选择功能2时,进入浏览航班信息模块【4】当选择功能3时,进入查找航班信息模块【5】当选择功能4时,进入航班排序模块,有两种选择一是从航班号从大到小,二是从航班号从小到大【6】当需要订票时,可以选择功能5进入订票模块
7、,【7】当有的乘客需要退票时也可以进入退票模块第三章 算法实现3.1 数据结构航空管理系统是一个数据库应用系统,航班的所有信息都保存在数据库中。3.2 程序模块 为实现函数功能特定义一下函数模型,具体程序参考程序源代码模块void add();/函数声明增加航班信息函数void print(); /显示航班信息void search();/查找航班信息void dingpiao();/订票业务void tuipiao();/退票void read();/读取文件void save();/保存文件void output();/输出格式void paixu();/航班排序void chushihu
8、a();/系统初始化void build();/建立数据文件void paixu1();/按航班号从小到大排序void paixu2();/从大到小3.3 各模块之间的调用关系程序从主函数开始,首先调用chushihua函数用来判断系统本身是否已经有原始数据文件,如果已经有原始数据则调用read函数否则调用build函数用来创建数据文件。进入系统开始页面,当进入增加航班信息模块时调用add函数和save函数,进入浏览信息模块后调用print函数来显示已有数据文件,进入查询信息模块调用search函数,dingpiao和tuipiao函数中首先调用search函数,然后在相应的增加或者是减少飞机
9、航票。3.4 程序源代码#include<stdio.h>#include<string.h>#include<process.h>#define N 9999/定义最多的航班数#define PRINT "%dtt%stt%stt星期%stt%dn ",si.num,si.start,si.over,si.time,si.count /宏定义输出格式struct air /定义结构体数组int num;char start20;char over20;char time10;int count;sN;int i,m=0;/定义全局变量c
10、har ii10;void add();/函数声明增加航班信息函数void print(); /显示航班信息void search();/查找航班信息void dingpiao();/订票业务void tuipiao();/退票void read();/读取文件void save();/保存文件void output();/输出格式void paixu();/航班排序void chushihua();/系统初始化void build();/建立数据文件void paixu1();/按航班号从小到大排序void paixu2();/从大到小void main()/主函数int j; chushi
11、hua();/系统初始化判断是否存在原始数据文件printf(" 欢迎使用飞机订票系统n");do printf("= "); printf("1.增加航班信息n" "t2.浏览航班信息n" "tt3.查找航班信息(按航班号)tt(_)n" "ttt4.航班排序(按航班号)n" "tttt5.订票业务n" "to()ottt6.退票业务n" "tttttt0.退出n");printf("= ");
12、 printf("请在0-6中选择以回车键结束: ");scanf("%d",&j);fflush(stdin);switch(j)case 1: add();break;case 2:print();break;case 3:search();break;case 4:paixu();break;case 5:dingpiao();break;case 6:tuipiao();break; case 0:save();printf("谢谢使用,再见! ");break;default:printf("您输入不合法,
13、请按回车键继续");getchar(); while(j!=0);/判断是否调用其他函数 void chushihua()/定义系统初始化函数if(access("hangban.dat",0)build();elseread();void build()/定义建立数据文件函数FILE *fp;/定义文件指针if(fp=fopen("hangban.dat","wb")=NULL)/打开文件并判定是否出错 printf("创建文件失败! ");getchar();return;printf("请
14、依次输入航班信息(以回车键结束):n"); printf("- n");for(i=0;i<N;i+)printf("请输入航班号: "); scanf("%d",&si.num);printf("请输入起始站: ");scanf("%s",si.start);printf("请输入终点站: ");scanf("%s",si.over);printf("请输入时间(星期几): ");scanf("%s&
15、quot;,si.time);printf("请输入机票数: ");scanf("%d",&si.count);fwrite(&si,sizeof(struct air),1,fp);m+;printf("添加完毕,是否继续添加?请键入y或n以回车键结束:");scanf("%s",ii);if(strcmp(ii,"y")!=0)/判断是否继续添加航班信息fclose(fp);/关闭文件return;void read()/定义读取文件函数FILE *fp;if(fp=fope
16、n("hangban.dat","r")=NULL)printf("创建文件失败! ");getchar();return;i=0;while(!feof(fp)fread(&si,sizeof(struct air),1,fp);/逐块读取数据i+;m+;/计算存在航班数m-;fclose(fp);void save()/定义保存函数FILE *fp;if(fp=fopen("hangban.dat","wb")=NULL) printf("创建文件失败! ");g
17、etchar();return;for(i=0;i<m;i+)/逐块保存数据fwrite(&si,sizeof(struct air),1,fp);fclose(fp);void add()/定义增加航班信息函数doprintf("请依次输入您要增加的航班信息(以回车键结束): n"); /打印提示信息printf("- n");printf("请输入航班号: "); scanf("%d",&sm.num);printf("请输入起始站: ");scanf("%s
18、",sm.start);printf("请输入终点站: ");scanf("%s",sm.over);printf("请输入时间: ");scanf("%s",sm.time);printf("请输入机票数: ");scanf("%d",&sm.count);m+;printf("添加完毕,是否继续添加?请键入y或n以回车键结束:");scanf("%s",ii);while(!strcmp(ii,"y&qu
19、ot;);/判断是否继续添加void output()/定义输出格式函数printf("航班号tt起始站tt终点站tt时间tt机票数n"); for(i=0;i<m;i+)printf(PRINT);/打印出信息void print()/定义显示航班信息函数printf("n目前我们有如下航班:n");output();/调用输出格式函数printf("n请按回车键返回上层菜单 ");getchar();getchar(); void search()/定义查询函数int n;doprintf("n请输入航班号: &q
20、uot;);scanf("%d",&n);/输入查询的航班号for(i=0;i<m;i+) if(si.num=n)/按航班号判定输出条件 printf("n您所查找的航班信息为:n ");printf("航班号tt起始站tt终点站tt时间tt机票数 nn");printf(PRINT);/显示信息 printf("n查询完毕,按回车键继续");getchar();getchar();return;printf("n对不起,没有您需要的信息!n ");printf("是否
21、重新查找?请键入y或n以回车键结束 ");scanf("%s",ii);while(!strcmp(ii,"y");/判定是否重新查找 void dingpiao()/定义订票业务函数int n;char a10="y"dosearch();/调用查询模块if(!strcmp(ii,"n")printf("对不起!没有找到您所需要的航班,所以不能订票。n");printf("n请按回车键返回上层菜单 ");getchar();getchar();strcpy(ii,
22、"n");break;doprintf("请输入您要订的机票数(以回车键结束): ");scanf("%d",&n);if(n<=0)/判定机票数是否出错printf("输入错误!至少需订1张机票。n");else if(si.count=0)/判定机票是否售完printf("对不起,你所选择的航班的机票已售完!n");break;else if(si.count!=0&&si.count>=n)/判定机票数是否大于等于订票数si.count=si.count
23、-n;printf("订票成功! ");break;else if(si.count<n)/判定机票数是否小于订票数 printf("对不起,你所选择的航班只剩 %d张机票n", si.count);printf("是否需要重新输入机票数?请输入y或n以回车键结束: ");/判定是否重新输入订票数scanf("%s",a);while(!strcmp(a,"y");printf("是否需要订其他航班的机票?请输入y或n以回车键结束: ");scanf("%s&
24、quot;,a);while(!strcmp(a,"y");/判定是否继续订票void tuipiao()/定义退票函数int n;char a10;dosearch();/调用查询函数if(!strcmp(ii,"n")printf("对不起!没有找到您所需要的航班,所以不能退票。n");printf("n请按回车键返回上层菜单 ");getchar();getchar();strcpy(ii,"n");break;printf("请输入您要退的机票数目: ");scanf
25、("%d",&n);if(n<=0)/判定票数是否有效printf("输入错误!至少需退1张机票。 ");else si.count=si.count+n;printf("退票成功! ");printf("是否继续? 请键入y或n以回车键结束: ");/判定是否继续退票scanf("%s",a);while(!strcmp(a,"y");/判定并跳出循环 void paixu()/定义排序函数int n;printf("n* "); prin
26、tf("1.按航班号从小到大排序n" "t2.按航班号从大到小排序n");printf("* "); printf("请在1-2中选择以回车键结束: ");scanf("%d",&n);switch(n)case 1:paixu1();/调用从小到大排序函数break;case 2:paixu2();/调用从大到小排序函数break;printf("排序后的航班信息为:n");output();/显示排序后航班信息printf("n请按回车键返回上层菜单 &
27、quot;); getchar(); getchar();void paixu1()/定义从小到大排序函数int k,j;struct air t;for(i=0;i<m;i+)/选择法排序k=i;for(j=i+1;j<m;j+)if(sk.num>sj.num)k=j;if(i!=k)t=sk;sk=si;si=t;void paixu2()/定义从大到小排序函数int k,j;struct air t;for(i=0;i<m;i+)k=i;for(j=i+1;j<m;j+)if(sk.num<sj.num)k=j;if(i!=k)t=sk;sk=si;si=t;第四章 测试与分析4.1测试数据选择 表4-14.2测试结果分析在输入测
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 电池制造中的人力资源管理与招聘培训考核试卷
- 海水淡化处理中的关键装备与材料考核试卷
- 植物油加工中的产品研发与创新考核试卷
- 仪器仪表制造业的品牌推广与传播考核试卷
- 区块链在教育中的应用考核试卷
- 春节团圆安全生产的领航者考核试卷
- DB11∕T 1767-2020 再生水利用指南 第1部分:工业
- 黄色梅花课件教学课件
- 谈心交流课件教学课件
- 淮阴工学院《理财规划》2022-2023学年第一学期期末试卷
- 船舶租赁尽职调查
- 统编教学小学语文课外阅读《细菌世界历险记》导读课课件
- 植物生理学-植物的逆境生理
- 【课件】比的基本性质
- 小学英语人教新起点五年级上册Unit3Animalsunit3storytime
- 2023年江苏省淮安市中考化学试卷
- 医疗质量管理与持续改进工作记录
- 小学英语名师工作室工作计划2篇
- 中国旅游嘉兴风土人情城市介绍旅游攻略PPT图文课件
- 出口退税培训课件
- 校外培训机构消防演练方案(精选10篇)
评论
0/150
提交评论