C语言课程设计-简易公交车管理系统(数组实现)_第1页
C语言课程设计-简易公交车管理系统(数组实现)_第2页
C语言课程设计-简易公交车管理系统(数组实现)_第3页
C语言课程设计-简易公交车管理系统(数组实现)_第4页
C语言课程设计-简易公交车管理系统(数组实现)_第5页
已阅读5页,还剩16页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

精品文档C语言课程设计——简易公交车管理系统(数组实现)可编辑可编辑精品文档可编辑/**************************头文件声明************************************/#include"stdio.h"#include"stdlib.h"#include"string.h"#include"conio.h"/**************************函数声明************************************/voidinit(); //初始化函数voidadd();//信息录入函数voidview();//信息显示函数voidmod();//信息修改函数voidmodmeun();//修改菜单voidmodnavimeun();//路线修改菜单voiddel();//信息删除函数voidfind();//信息查询函数voidfindmeun();//查询菜单voidfindnavi();//路线导航查询函数voidfindnum();//路线编号查询函数voidfindstameun();//站台信息查询菜单voidfindsta();//站台信息查询函数voidsave();//信息保存函数voidmainmeun();//主菜单charTest(chara,charb,charc);//菜单输入检测函数/**************************宏定义声明************************************/#defineN100//公交车数量/**************************结构体定义************************************/structstation//途径站点信息{ charc[20];//站点名称};structbus//公交车信息{ charnum[20];//公交车路线编号 charname[20];//司机姓名C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第1页。 intn;//站台数目C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第1页。 structstationb[12];//站台名称 chartopen[20];//起始时间 chartclose[20];//终止时间 intmoney;//票价}a[N];/**************************函数定义************************************/intmain(){ chara; init(); printf("\n\t\t目前所能录入的公交车数量上限为%d辆\n\n",N); printf("\n\t\t输入回车键继续\n"); fflush(stdin);//清除键盘缓冲区 while(1) { system("cls"); mainmeun(); a=Test(getchar(),'1','6');//菜单检测输入函数 switch(a) { case'1': system("cls");add();break; case'2': system("cls");view();break; case'3': system("cls");mod();break; case'4': system("cls");del();break; case'5':system("cls");find();break; case'6':return0; } } return0;}voidinit()//初始化函数{ FILE*fp;//文件指针 inti;C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第2页。 if((fp=fopen("bus.txt","r+"))==NULL)//初次尝试打开"bus.txt"文本文件C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第2页。 { printf("\n\t\t文件打开失败\n\n\t\t正在尝试创建新文件...\n"); fp=fopen("bus.txt","w");//创建"bus.txt"文本文件 if((fp=fopen("bus.txt","r+"))==NULL)//再次判断是否打开成功 { printf("\t\t文件创建失败!!!\n"); return; } } fp=fopen("bus.txt","r+"); for(i=0;i<N;i++)//将磁盘中的信息输出到内存中 if(fread(&a[i],sizeof(structbus),1,fp)!=1) break; fclose(fp); printf("\n\t\t初始化完成!!!\n\n"); return;}voidadd()//信息录入函数{ FILE*fp=NULL;//文件指针 inti,j; charcc[20]; for(i=0;i<N;i++) { if(*a[i].num!='\0') continue; else { printf("\n添加第%d辆公交车路线记录:\n",i+1); printf("\n请输入路线编码(3位编码,第一位为大写字母,后两位为数字):\n");//路线编码 scanf("%s",cc); for(j=0;j<N;j++)//检验是否重复 if(strcmp(a[j].num,cc)==0)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第3页。 {C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第3页。 printf("\n与已有路线编码重复,按回车键返回!!!\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return; } strcpy(a[i].num,cc); printf("\n请输入司机姓名:");//司机姓名 scanf("%s",a[i].name); printf("\n请输入途径站台总数(>=2):");//站台总数 scanf("%d",&a[i].n); printf("\n"); if(a[i].n<2||a[i].n>12) { while(a[i].n<2||a[i].n>12) { printf("\n站台总数应满足(2<=n<=12),请重新输入:"); scanf("%d",&a[i].n); printf("\n"); } } for(j=0;j<a[i].n;j++) { printf("请输入第%d个站台名称:",j+1);//站台名称 scanf("%s",a[i].b[j].c); } printf("\n自动生成公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) { printf("---->(%d)%s",j+1,a[i].b[j].c); } printf("\n\n请输入公交车的起始时间(格式为:时:分):");//起始时间 scanf("%s",a[i].topen); printf("请输入公交车的终止时间(格式为:时:分):");//终止时间C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第4页。 scanf("%s",a[i].tclose);C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第4页。 printf("\n请输入公交车的票价:");//票价 scanf("%d",&a[i].money); printf("\n第%d辆公交车路线记录创建成功!!!\n",i+1); save(); printf("\n\t按回车键返回!!!\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return; } } if(i==N) printf("\n\n\n\t空间已满,不能录入!!!\n"); printf("\n\t按回车键返回!!!\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;}voidview()//信息显示函数{ inti,j,min; structbust; for(i=0;*a[i].num!='\0'&&i<N;i++)//按“路线编号”用选择法排序 { min=i; for(j=i+1;*a[j].num!='\0'&&j<N;j++) if(strcmp(a[i].num,a[j].num)>0) min=j; t=a[i]; a[i]=a[min]; a[min]=t; } printf("\n\n公交车信息库"); printf("\n********************************************************************************\n");C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第5页。 for(i=0;*a[i].num!='\0'&&i<N;i++)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第5页。 { printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name); printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); } printf("\n********************************************************************************\n"); printf("\n\t\t公交车信息显示完毕!!!\n"); printf("\n\t\t输入回车键返回主菜单:"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;}voidmod()//信息修改函数{ inti,j,m=0; chart,cc[20],mod[20]; printf("请输入要修改信息的公交车路线编号:\n"); scanf("%s",cc); for(i=0;*a[i].num!='\0'&&i<N;i++)//查找所输入的公交车 { if(strcmp(a[i].num,cc)==0) { m=1; printf("\n\n\t\t已找到!!!\n"); while(1) { system("cls"); printf("\n\n正在修改的公交车信息\n");C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第6页。 printf("\n-----------------------------------------------\n");C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第6页。 printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name); printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); printf("\n-----------------------------------------------\n\n"); modmeun(); fflush(stdin);//清除键盘缓冲区 t=Test(getchar(),'1','5');//菜单检测输入函数 system("cls"); switch(t) { case'1'://修改路线编号 { intk; printf("\n请输入新的公交车编号:"); scanf("%s",mod); for(k=0;*a[k].num!='\0'&&k<N;k++) { if(strcmp(a[k].num,mod)==0) { printf("与已有编号重复,按回车键返回主菜单\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return; } } strcpy(a[i].num,mod); save(); break; }C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第7页。 case'2'://修改车辆信息C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第7页。 { printf("\n请输入新的司机姓名:"); scanf("%s",a[i].name); printf("\n请输入新的公交车票价:"); scanf("%d",&a[i].money); save(); break; } case'3'://修改行车路线 { voidmodnavimeun();//路线修改菜单 intk; charz; while(1) { system("cls"); modnavimeun(); fflush(stdin);//清除键盘缓冲区 z=Test(getchar(),'1','5');//菜单检测输入函数 system("cls"); switch(z) { case'1'://添加站点 { if(a[i].n+1>12)//判断是否满足条件 { printf("\n站台总数达到12个,无法添加新站点\n\n按回车键返回\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return; } printf("\n请输入需要添加第几个站点:"); scanf("%d",&k);C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第8页。 while(a[i].n+1<k)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第8页。 { printf("目前共%d个站点,无法添加第%d个站点\n请重新输入:",a[i].n,k); scanf("%d",&k); printf("\n"); } a[i].n=a[i].n+1; for(j=a[i].n;j>k-1;j--) { a[i].b[j]=a[i].b[j-1]; } printf("\n请输入新添加的站点名称:"); scanf("%s",a[i].b[k-1].c); save(); break; } case'2'://修改站点 { printf("\n请输入需要修改第几个站点:"); scanf("%d",&k); printf("\n请输入新的站点名称:"); scanf("%s",a[i].b[k-1].c); save(); break; } case'3'://删除站点 { printf("\n请输入需要删除第几个站点:"); scanf("%d",&k); for(j=k-1;j<a[i].n;j++) { a[i].b[j]=a[i].b[j+1]; } a[i].n=a[i].n-1; save(); break; } case'4'://重置路线C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第9页。 {C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第9页。 printf("\n请输入新的途径站台总数(2<=n<=12):"); scanf("%d",&a[i].n); printf("\n"); while(a[i].n<2||a[i].n>12)//判断是否满足条件 { printf("\n站台总数应满足(2<=n<=12),请重新输入:"); scanf("%d",&a[i].n); printf("\n"); } for(j=0;j<a[i].n;j++) { printf("请输入新的第%d个站台名称:",j+1); scanf("%s",a[i].b[j].c); } printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); save(); break; } case'5'://返回菜单 { printf("\n\t\t按回车键返回菜单\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;//返回主菜单 } } } } case'4'://修改行车时间C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第10页。 {C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第10页。 printf("\n\n请输入公交车的起始时间(格式为:时:分):"); scanf("%s",a[i].topen); printf("请输入公交车的终止时间(格式为:时:分):"); scanf("%s",a[i].tclose); save(); break; } case'5': { printf("\n\t\t按回车键返回主菜单\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;//返回主菜单 } } } } } if(m==0) printf("\n\n\t\t无此公交车信息!!!\n"); printf("\n\t\t按回车键返回\n"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;}voidmodmeun()//修改菜单{ printf("\n\t\t修改菜单"); printf("\n\t\t********************************************"); printf("\n\t\t*1、修改路线编号*"); printf("\n\t\t*2、修改车辆信息*"); printf("\n\t\t*3、修改行车路线*"); printf("\n\t\t*4、修改行车时间*");C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第11页。 printf("\n\t\t*5、返回到主菜单*");C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第11页。 printf("\n\t\t********************************************"); printf("\n\n\t\t请输入您的选择:");}voidmodnavimeun()//路线修改菜单{ printf("\n\t\t路线修改菜单"); printf("\n\t\t********************************************"); printf("\n\t\t*1、站点添加*"); printf("\n\t\t*2、站点修改*"); printf("\n\t\t*3、站点删除*"); printf("\n\t\t*4、路线重置*"); printf("\n\t\t*5、返回菜单*"); printf("\n\t\t********************************************"); printf("\n\n\t\t请输入您的选择:");}voiddel()//信息删除函数{ inti,j,t,m=0; charcc[20]; printf("\n请输入要删改信息的公交车路线编号:\n"); scanf("%s",cc); for(i=0;*a[i].num!='\0'&&i<N;i++)//查找所输入的公交车 { if(strcmp(a[i].num,cc)==0) { m=1; printf("\n已找到:\n"); printf("\n-----------------------------------------------\n"); printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name); printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第12页。 printf("---->(%d)%s",j+1,a[i].b[j].c);C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第12页。 printf("\n\n"); printf("\n-----------------------------------------------\n\n"); printf("即将删除该公交车信息!!!\n确定请按1:"); scanf("%d",&t); if(t==1) { if(i+1==N) memset(&a[i],'\0',sizeof(structbus));//最后一辆直接进行清空 else for(j=i;*a[j].num!='\0'&&j+1<N;j++)//后面的公交车信息补上删去的公家车信息 a[j]=a[j+1]; printf("编号为%s的公交车信息删除完毕!\n",cc); save(); break; } } } if(m==0) printf("\n\n\t\t无此公交车信息!!!\n"); printf("\n\n\t输入回车键返回主菜单:"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;}voidfind()//信息查询函数{ chart; while(1) { findmeun(); fflush(stdin);//清除键盘缓冲区 t=Test(getchar(),'1','4');//菜单检测输入函数 switch(t)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第13页。 {C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第13页。 case'1':system("cls");findnavi();break;//路线导航查询 case'2':system("cls");findnum();break;//路线编号查询函数 case'3':system("cls");findsta();break;//站台信息查询函数 case'4':system("cls");return;//返回主菜单 } } return;}voidfindmeun()//查询菜单{ printf("\n\t\t查询菜单"); printf("\n\t\t********************************************"); printf("\n\t\t*1、路线导航查询*"); printf("\n\t\t*2、路线编号查询*"); printf("\n\t\t*3、站台信息查询*"); printf("\n\t\t*4、返回到主菜单*"); printf("\n\t\t********************************************"); printf("\n\n\t\t请输入您的选择:");}voidfindnavi()//路线导航查询函数{ inti,j,k,m=0; charc1[20],c2[20]; printf("请输入您目前所在的站点:\n\t\t"); scanf("%s",c1); printf("请输入您想要前往的站点:\n\t\t"); scanf("%s",c2); printf("\n\n您可选择的公交车信息如下\n"); printf("\n-----------------------------------------------\n"); for(i=0;*a[i].num!='\0'&&i<N;i++) { for(j=0;j<a[i].n;j++) for(k=j+1;k<a[i].n;k++) if(strcmp(a[i].b[j].c,c1)==0&&strcmp(a[i].b[k].c,c2)==0)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第14页。 {C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第14页。 m=1; printf("\n"); printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name); printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); } } printf("\n-----------------------------------------------\n\n"); printf("\t\t\t\t显示完毕\n"); if(m==0) printf("\n\n\t\t\t\t抱歉,无途径此路线的公交车\n"); printf("\n\t\t\t\t输入回车键返回查询菜单:"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;}voidfindnum()//路线编号查询函数{ inti,j,m=0; charcc[20]; printf("请输入您想要查找的公交路线编号:\n"); scanf("%s",cc); for(i=0;*a[i].num!='\0'&&i<N;i++) { if(strcmp(a[i].num,cc)==0) { m=1; printf("\n已找到:\n"); printf("\n-----------------------------------------------\n");C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第15页。 printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name);C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第15页。 printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); printf("\n-----------------------------------------------\n\n"); break; } } if(m==0) printf("\n\t\t无此公交车信息\n"); printf("\n\t\t输入回车键返回查询菜单:"); fflush(stdin);//清除键盘缓冲区 getchar(); system("cls"); return;}voidfindstameun()//站台信息查询菜单{ printf("\n\t\t站台信息查询菜单"); printf("\n\t\t********************************************"); printf("\n\t\t*1、起始站台查询*"); printf("\n\t\t*2、终止站台查询*"); printf("\n\t\t*3、途径站台查询*"); printf("\n\t\t*4、返回查询菜单*"); printf("\n\t\t********************************************"); printf("\n\n\t\t请输入您的选择:");}voidfindsta()//站台信息查询函数{ inti,j,k; chart;C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第16页。C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第16页。 while(1) { intm=0; findstameun(); fflush(stdin);//清除键盘缓冲区 t=Test(getchar(),'1','4');//菜单检测输入函数 system("cls"); switch(t) { case'1': { printf("请输入您所要查询的起始站台名称:\n"); scanf("%s",cc); printf("\n以%s为起始站台的公交车如下:\n",cc); printf("\n-----------------------------------------------\n"); for(i=0;*a[i].num!='\0'&&i<N;i++) { if(strcmp(a[i].b[0].c,cc)==0) { m=1; printf("\n"); printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name); printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); } } printf("\n-----------------------------------------------\n\n"); printf("\t已全部显示完毕!!!\n"); if(m==0) printf("\n\t没有公交车以该站点为起始站台\n"); break;C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第17页。 }C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第17页。 case'2': { printf("请输入您所要查询的终止站台名称:\n"); scanf("%s",cc); printf("\n以%s为终止站台的公交车如下:\n",cc); printf("\n-----------------------------------------------\n"); for(i=0;*a[i].num!='\0'&&i<N;i++) { k=a[i].n; if(strcmp(a[i].b[k-1].c,cc)==0) { m=1; printf("\n"); printf("\t路线编号:%-6s\t单程票价:%d元\t\t司机姓名:%s\n",a[i].num,a[i].money,a[i].name); printf("\t起始时间:%-6s\t终止时间:%-6s\t站台总数:%d\n",a[i].topen,a[i].tclose,a[i].n); printf("\t公交路线:(1)%s",a[i].b[0].c); for(j=1;j<a[i].n;j++) printf("---->(%d)%s",j+1,a[i].b[j].c); printf("\n\n"); } } printf("\n-----------------------------------------------\n\n"); printf("\t已全部显示完毕!!!\n"); if(m==0) printf("\n\t没有公交车以该站点为起始站台\n"); break; } case'3': { printf("请输入您所要查询的途径站台名称:\n"); scanf("%s",cc); printf("\n-----------------------------------------------\n"); for(i=0;*a[i].num!='\0'&&i<N;i++)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第18页。 for(k=1;k<a[i].n-1;k++)C语言课程设计——简易公交车管理系统(数组实现)全文共21页,当前为第18页。 if(strcmp(a[i].b[k].c,cc)==0)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论