C语言飞机订票系统课程设计.doc
《C语言飞机订票系统课程设计.doc》由会员分享,可在线阅读,更多相关《C语言飞机订票系统课程设计.doc(33页珍藏版)》请在咨信网上搜索。
C语言飞机订票系统课程设计 33 2020年4月19日 文档仅供参考 第一章 绪论 1.1:项目背景描述 1、课程设计性质与目的: C语言程序设计是一门实践性很强的课程。C程序课程设计是学习C语言 程序设计的非常重要的实践环节,经过本课程设计使学生进一步巩固课堂所 学,全面熟悉,掌握C语言程序设计的基本方法和技巧,进一步提高编写程 序、分析程序及上机操作、调试程序的能力,让学生加深理解,提高动手操作能力及分析问题和解决问题的能力。 2、课程设计包含的知识点: 1.掌握并熟练利用C语言的基本数据类型与各种表示式,程序的流程控制语 句。 2.掌握数组的基本概念。掌握一维数组与二维数组的使用,掌握字符数组与 字符串的关系。 3.熟练掌握指针、地址、指针类型的概念及其使用。掌握指针变量的定义与初始化、指针的间接访问和表示式,掌握指针与数组、函数、字符串的联系 4.掌握函数的定义,函数的返回值,函数的调用,函数的声明,函数的形式参数和实际参数之间的关系,了解函数的作用区间。 5.掌握结构体的概念,结构体类型的定义,结构体变量的定义和初始化,结构体成员的表示。结构体与指针、函数的关系。 第二章 可行性分析 一、问题描述: 假设某航空公司只有N架X个座位的飞机,每架飞机每天飞行一趟。经过该系统来实现机票的订购问题。 二、功能要求: 1、本系统采用一个包含N个数据的结构体数组,每个数据的结构应当包括:起飞地、目的地 航班号、航班定额。 2、本系统显示这样的菜单: 1.)录入: 能够录入航班情况(数据能够存储在一个数据文件中) 2.)浏览:航班信息浏览功能需要提供显示操作; 1、 查询:可提供按照航班号、起点站、终点站、飞行时间、查询,能够查询某个航线的情况(如,输入航班号,起飞抵达城市,确定航班是否满仓);另外要提供键盘式选择菜单以实现功能选择。 (1) 输入航班信息 (2) 输出航班信息 (3) 查找航班信息 (4)订票预约 (5)删除定票预约 (6)退出系统 2、 本系统成功执行菜单的每个信息,选项4)和5)将要求额外的输入,而且它们都允许用户收回其输入。 3、 查找航班信息既可按线路查,也可按目的地查。 4、在两次运行之间,数据被保存于一个文件里,当本程序重新开 始的时候,它首先从该文件读入数据 三、算法提示: 1、数据结构:结构体类型数组 2、数据库结构:下表构成该系统的基本数据库。 航班号 起点 终点 起飞时间 int char char char 四、测试数据: 录入北京到上海的星期一起飞的航班,假设其定额为30,上海到南京的航班起飞时间为星期二。 五、其它: 在实现系统基本功能后,完善系统的其它功能。在测试数据是发现退票系统出现问题,退票数会超过定额,在加上一个限定条件后成功。基于本系统能够尝试输出所定票的的顾客的完整信息,包括姓名,身份证号等个人信息,由于时间有限,尚未添加。 第三章 总体设计 3.1 课程设计题目: 航班订票系统 3.2. 内容摘要: 假设某航空公司只有M架N个座位的飞机,每架飞机每天飞行一趟。经过该系统来实现机票的订购问题。 3.3. 关键字: 函数 数组 结构体 文件 循环语句 多分支结构 3.4.总体设计方案的选定: 程序的功能要求: 1、本系统采用一个包含N个数据的结构体数组,每个数据的结构应当包括:起飞地、目的地 航班号、座次号码、座次订出与否标记、订座者的姓名和订座者的身份证号码。 2、本系统显示这样的菜单: (4) 输入航班信息 (5) 输出航班信息 (6) 查找航班信息 a.显示空座的数量 b.显示空座的信息 c.显示已订座的信息 d.起飞时间 (4)订票预约 (5)删除定票预约 (6)退出系统 4、 本系统成功执行菜单的每个信息,选项4)和5)将要求额外的输入,而且它们都允许用户收回其输入。 5、 查找航班信息既可按航班号来实现。 4、在两次运行之间,数据被保存于一个文件里,当本程序重新开始的时候,它首先从该文件读入数据 第四章 详细设计 4.1采用自定向下,逐步细化的思想,将该系统分解成各个相对独立且能够运行的模块。 在文件的开始定义出本系统中将会用到的所有的变量以及对各个模块的调用,将作为头文件使各个组员能够使用。如下所示: hangban.h #include<stdio.h> //标准输入、输出头文件 #include<string.h> //包含字符串函数处理头文件 #define N 9999 //定义最多的航班数 #define PRINT "%d\t\t%s\t\t%s\t\t星期%s\t\t%d\n ",s[i].num,s[i].qidian,s[i].zhongdian,s[i].time,s[i].count //宏定义输出格式 struct air //定义结构体数组 { int num; //定义航班号 char qidian[20]; //航班起始站 char zhongdian[20]; //终点站 char time[10]; //飞行时间 int count; //机票数量 }s[N]; int i,m=0; //定义全局变量 char hangbanhao[10]; void add(); //函数声明增加航班信息函数 void print(); //显示航班信息 void search(); //查找航班信息 void dingpiao(); //订票业务 void tuipiao(); //退票 void read(); //读取文件 void save(); //保存文件 void output(); //输出格式 void paixu(); //航班排序 void build(); //建立数据文件 void paixu1(); //按航班号从小到大排序 void paixu2(); //从大到小 4.2系统总体结构 4.3航班信息录入流程图 4.4订票系统流程图 在有航班信息的情况下能够进行订票操作。 开始 查询所有 是 否 输入航班号 显示航班信息 确定订票 否 保存 4.5查询结构代码 void search() //定义查询函数 { int n; do { printf("\n请输入航班号: "); scanf("%d",&n); //输入查询的航班号 for(i=0;i<m;i++) { if(s[i].num==n) //按航班号判定输出条件 { printf("\n您所查找的航班信息为:\n "); printf("航班号\t\t起始站\t\t终点站\t\t时间\t\t机票数 \n\n"); printf(PRINT); //显示信息 printf("\n查询完毕,按回车键继续"); getchar(); getchar(); return; } } printf("\n对不起,没有您需要的信息!\n "); printf("是否重新查找?请键入y或n以回车键结束 "); scanf("%s",hangbanhao); }while(!strcmp(hangbanhao,"y"));//判定是否重新查找 } 4.6订票业务代码 void dingpiao() //定义订票业务函数 { int n; char a[10]="y"; do { search(); //调用查询模块 do { printf("请输入您要订的机票数(以回车键结束): "); scanf("%d",&n); //输入所订机票数 if(n<=0) //判定机票数是否出错 { printf("输入错误!至少需订1张机票。\n"); } else if(s[i].count==0)//判定机票是否售完 { printf("对不起,你所选择的航班的机票已售完!\n"); break; } else if(s[i].count!=0&&s[i].count>=n) //判定机票数是否大于等于订票数 { s[i].count=s[i].count-n; printf("订票成功! "); break; } else if(s[i].count<n)//判定机票数是否小于订票数 { printf("对不起,你所选择的航班只剩 %d张机票\n", s[i].count); printf("是否需要重新输入机票数?请输入y或n以回车键结束: ");//判定是否重新输入订票数 scanf("%s",a); } }while(!strcmp(a,"y")); printf("是否需要订其它航班的机票?请输入y或n以回车键结束: "); scanf("%s",a); }while(!strcmp(a,"y")); //判定是否继续订票 } 4.7退票业务代码 void tuipiao() //定义退票函数 { int n; char a[10]; do { search(); //调用查询函数 printf("请输入您要退的机票数目: "); scanf("%d",&n); //输入所退票数 if(n<=0) //判定票数是否有效 printf("输入错误!至少需退1张机票。 "); else { s[i].count=s[i].count+n; printf("退票成功! "); } printf("是否继续? 请键入y或n以回车键结束: "); //判定是否继续退票 scanf("%s",a); }while(!strcmp(a,"y")); //判定并跳出循环 } 第五章 总结 一周的C语言课程设计即将结束,经过此次课程设计也学会综合运用理论知识来分析和解决实际问题的能力、养成严谨的科学态度和良好的程序设计习惯实现由知识向智能的初步转化学会循软件开发过程的基本规范运用结构化程序设计的方法按照课程设计的题目要求并能够完成设计、编写、调试和测试应用程序及编写文档的任务 程序整体上运行与题目要求很吻合算法大多比较通用各个函数模块的正确性、完备性、对输入的容错能力以及算法的进一步改进在设计中都有表述这道题使我熟悉了文件的输入输出操作真切的感受到了fprintf和fwrite函数的区别。 回顾起此次课程设计至今我仍感慨颇多从理论到实践在整整半个月的日子里我学到很多很多的东西不但巩固了以前所学过的知识而且学到了很多在书本上所没有学到过的内容。经过这次课程设计使我懂得了理论与实际相结合是很重要的只有理论知识是远远不够的只有把所学的理论知识与实践相结合起来从理论中得出结论才是真正的知识才能提高自己的实际动手能力和独立思考的能力。在设计的过程遇到了各种各样的问题同时在设计的过程中发现了自己的不足之处对以前所学过的知识理解得不够深刻掌握得不够牢固经过这次课程设计把以前所学过的知识重新温故巩固了所学的知识。 在编写程序的过程中受到了其它同学的指点可能在某些程序方面会和有的同学想类似可是老师在我编程序过程中也起到了很大的作用我们在C语言这门课上还会继续走下去以后还会经常碰到我会努力。 附1: 源代码 #include<stdio.h> //标准输入、输出头文件 #include<string.h> //包含字符串函数处理头文件 #define N 9999 //定义最多的航班数 #define PRINT "%d\t\t%s\t\t%s\t\t星期%s\t\t%d\n ",s[i].num,s[i].qidian,s[i].zhongdian,s[i].time,s[i].count //宏定义输出格式 struct air //定义结构体数组 { int num; //定义航班号 char qidian[20]; //航班起始站 char zhongdian[20]; //终点站 char time[10]; //飞行时间 int count; //机票数量 }s[N]; int i,m=0; //定义全局变量 char hangbanhao[10]; void add(); //函数声明增加航班信息函数 void print(); //显示航班信息 void search(); //查找航班信息 void dingpiao(); //订票业务 void tuipiao(); //退票 void read(); //读取文件 void save(); //保存文件 void output(); //输出格式 void paixu(); //航班排序 void build(); //建立数据文件 void paixu1(); //按航班号从小到大排序 void paixu2(); //从大到小 void main() //主函数 { int j; read(); printf("\n\t\t欢迎使用航班订票系统!\n"); printf("******************************************\n"); printf(" 1.增加航班信息\n"); printf(" 2.浏览航班信息\n"); printf(" 3.查找航班信息\n"); printf(" 4.航班排序(按航班号)\n"); printf(" 5.办理订票业务\n"); printf(" 6.办理退票业务\n"); printf(" 0.退出系统(exit)\n"); printf("*******************************************\n"); printf("请在0-6中选择以回车键结束: "); scanf("%d",&j); 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; } } void read() //定义读取文件函数 { FILE *fp; if((fp=fopen("hangban.dat","rb"))==NULL) { printf("创立文件失败! "); getchar(); return; } i=0; while(!feof(fp)) { fread(&s[i],sizeof(struct air),1,fp); //逐块读取数据 i++; m++; //计算存在航班数 } m--; fclose(fp); } void save() //定义保存函数 { FILE *fp; if((fp=fopen("hangban.dat","wb"))==NULL) { printf("创立文件失败! "); getchar(); return; } for(i=0;i<m;i++) //逐块保存数据 fwrite(&s[i],sizeof(struct air),1,fp); fclose(fp); } void add() //定义增加航班信息函数 { do{ printf("请依次输入您要增加的航班信息(以回车键结束): \n"); //打印提示信息 printf("-------------------------------------------------------------------------- \n"); printf("请输入航班号: "); scanf("%d",&s[m].num); //读取航班号 printf("请输入起始站: "); scanf("%s",s[m].qidian); //读取起始站 printf("请输入终点站: "); scanf("%s",s[m].zhongdian); //读取终点站 printf("请输入时间: "); scanf("%s",s[m].time); //读取时间 printf("请输入机票数: "); scanf("%d",&s[m].count); //读取机票数 m++; printf("添加完毕,是否继续添加?请键入y或n以回车键结束:"); scanf("%s",hangbanhao); }while(!strcmp(hangbanhao,"y")); //判断是否继续添加 } void output() //定义输出格式函数 { printf("航班号\t\t起始站\t\t终点站\t\t时间\t\t机票数\n"); //信息标题 for(i=0;i<m;i++) printf(PRINT);//打印出信息 } void print() //定义显示航班信息函数 { printf("\n当前我们有如下航班:\n"); output(); //调用输出格式函数 printf("\n请按回车键返回上层菜单 "); getchar(); getchar(); } void search() //定义查询函数 { int n; do { printf("\n请输入航班号: "); scanf("%d",&n); //输入查询的航班号 for(i=0;i<m;i++) { if(s[i].num==n) //按航班号判定输出条件 { printf("\n您所查找的航班信息为:\n "); printf("航班号\t\t起始站\t\t终点站\t\t时间\t\t机票数 \n\n"); printf(PRINT); //显示信息 printf("\n查询完毕,按回车键继续"); getchar(); getchar(); return; } } printf("\n对不起,没有您需要的信息!\n "); printf("是否重新查找?请键入y或n以回车键结束 "); scanf("%s",hangbanhao); }while(!strcmp(hangbanhao,"y"));//判定是否重新查找 } void dingpiao() //定义订票业务函数 { int n; char a[10]="y"; do { printf("请输入您要订的机票数(以回车键结束): "); scanf("%d",&n); //输入所订机票数 if(n<=0) //判定机票数是否出错 { printf("输入错误!至少需订1张机票。\n"); } else if(s[i].count==0)//判定机票是否售完 { printf("对不起,你所选择的航班的机票已售完!\n"); break; } else if(s[i].count!=0&&s[i].count>=n) //判定机票数是否大于等于订票数 { s[i].count=s[i].count-n; printf("订票成功! "); break; } else if(s[i].count<n)//判定机票数是否小于订票数 { printf("对不起,你所选择的航班只剩 %d张机票\n", s[i].count); printf("是否需要重新输入机票数?请输入y或n以回车键结束: ");//判定是否重新输入订票数 scanf("%s",a); } printf("是否需要订其它航班的机票?请输入y或n以回车键结束: "); scanf("%s",a); }while(!strcmp(a,"y")); //判定是否继续订票 } void tuipiao() //定义退票函数 { int n; char a[10]; do { search(); //调用查询函数 printf("请输入您要退的机票数目: "); scanf("%d",&n); //输入所退票数 if(n<=0) //判定票数是否有效 printf("输入错误!至少需退1张机票。 "); else { s[i].count=s[i].count+n; printf("退票成功! "); } printf("是否继续? 请键入y或n以回车键结束: "); //判定是否继续退票 scanf("%s",a); }while(!strcmp(a,"y")); //判定并跳出循环 } void paixu() //定义排序函数 { int n; printf("\n******************************************************************************** "); printf("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请按回车键返回上层菜单 "); 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(s[k].num>s[j].num) k=j; if(i!=k) { t=s[k]; s[k]=s[i]; s[i]=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(s[k].num<s[j].num) k=j; if(i!=k) { t=s[k]; s[k]=s[i]; s[i]=t; } } } 附2 参考资料 C程序设计 (第四版) 谭浩强 著 清华大学出版社- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 飞机 订票 系统 课程设计
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文