(已修改,请用最新的代码)代码说明:
1级菜单:选择购买的航班号,并显示对应座位状态。
(我只做测试,所以初始化initFlight函数中我只初始了2个航班,需要自己按照我的代码添)
(注意:实际开发软件,链表数据是从数据库中读取的,需要实时同步,如果要多次调用initFlight函数,记得自己写一个释放内存的函数,把所有链表“SINFO和FLINFO”节点都释放掉,释放函数我没写,需要你自己写!!!)
2级菜单:选择购买对应座位号,完成购买,并实时显示购买结果。
位置编号、座位最大排数、舱室类型、折扣等参数均由常量参数空值,需要修改自行改常量。
注意:舱室类型(我默认3个类型头等舱、公务舱、经济舱)对应折扣参数:tDiscount二维数组。如要如要添加新的舱室类型,必须将参数常量TYPESIZE、typeName、types、tDiscount这4个同时修改,具体看代码备注!!
座位票价=基础票价*类型折扣*时段折扣。
因为飞机不让吸烟,所以我没做吸烟区(笑),如果你需要,可以作为类型自行添加!
#include<stdio.h>#include<stdlib.h>
#include<conio.h>
#include<string.h>
#include<malloc.h>
#include<time.h>
//-----------------------相关参数,想改变,在这里修改!!!!!!!-----------------------------
const float timeDiscount=1//时段折扣,影响所有航班最终价格,默认1
const char cID[5]="ABCD"//位置编号
const int maxRow=20//位置最大排号
//注意:如果修改类型数量,types和tDiscount必须同时修改!!!
#define TYPESIZE 3//类型数量
const char typeName[TYPESIZE][10]={"头等舱","公务舱","经济舱"}
const int types[TYPESIZE][2]={{1,2},{3,4},{5,20}}//排号对应类型。1~2排头等舱,3~4排公务舱,5~20排经济舱
const float tDiscount[TYPESIZE]={1.5,1.3,1}//类型折扣。头等舱1.5倍,公务舱1.3倍,经济舱1倍
//-------------------------------------------------------------------------------
typedef struct seatInfo//座位信息,一条链表对应一个航班信息,链表顺序从第一排左边第一个开始往后A1~D1,A2~D2。。。
{
char cloID//位置编号A、B、C、D
int row//位置排号
int type//座位所属类型:0:头等舱、1:公务舱、2:经济舱,不同类型对应不同的类型折扣tDiscount
int sell//出售状态,0:未出售;1:已出售
struct seatInfo *next
}SINFO
typedef struct flightInfo//航班信息
{
char fid[10]//航班号
time_t tfTime//起飞时间
time_t ldTime//降落时间
char toCity[20]//抵达城市
float tPrice//基础票价,不同位置具有不同折扣,座位票价=基础票价*类型折扣*时段折扣
struct flightInfo *next
struct seatInfo *sHead//对应座位链表的头节点
}FLINFO
void meError(void *p)
SINFO *getSINFO()//获取座位链表
//addFLINFO:添加航班信息链表的节点flinfoHead:头节点(第一次传NULL会自动生成),flinfoTail:尾节点,fNew:要添加的结构信息(成员指针无需赋值)
FLINFO *addFLINFO(FLINFO **ffHead,FLINFO *flinfoTail,FLINFO fNew)//返回尾节点
time_t getTime_tfromStr(char *sTime)//将YYYY-MM-DD hh:mm:ss格式的时间字符串转换成time_t型数值
FLINFO *initFlight()//初始化航班信息,返回航班链表头节点,如果想手动输入,请在这里添加!!!正常软件开发,这一步应该是从数据库读取!
char *getTString(struct tm *tm0)//通过tm获取时间字符串
void showSinfo(FLINFO *flinfo)//显示航班对应座位信息
void printfFlinfo(FLINFO * flinfoHead)
FLINFO *selectFlinfo(FLINFO *flinfoHead,char *fid)//选择航班号,返回节点
void showSinfo(FLINFO *flinfo)//显示航班对应座位信息
SINFO *selectSinfo(FLINFO *flinfo,char *sid)//选择座位,返回节点
int main()
{
FLINFO *flinfoHead=initFlight(),*ffSelect=NULL
SINFO *sfSelect=NULL
char fid[10]={0},sid[10]={10}
while(1)
{
ffSelect=NULL
sfSelect=NULL
memset(fid,0,10)
memset(sid,0,10)
printfFlinfo(flinfoHead)
printf("请输入要购买的航班号:")
scanf("%s",fid)
ffSelect=selectFlinfo(flinfoHead,fid)
if(!ffSelect)
{
printf("未找到对应航班,按任意键继续-----\n")
getch()
system("cls")
continue
}
system("cls")
printf("航班号:%s 座位信息如下:\n",ffSelect->fid)
showSinfo(ffSelect)
printf("请输入要购买的座位编号(输入0返回主菜单):")
scanf("%s",sid)
if(!strcmp(sid,"0"))
{
system("cls")
continue
}
else
{
sfSelect=selectSinfo(ffSelect,sid)
if(!sfSelect||sfSelect->sell)
{
printf("未找到对应座位或该座位已出售,请重新输入!按任意键继续-----\n")
getch()
system("cls")
continue
}
printf("购买成功!按任意键继续-----")
sfSelect->sell=1
getch()
system("cls")
}
}
return 0
}
SINFO *selectSinfo(FLINFO *flinfo,char *sid)//选择座位,返回节点
{
SINFO *sinfoHead=flinfo->sHead
while(sinfoHead->next)
{
if(sinfoHead->next->cloID==sid[0] && sinfoHead->next->row==atoi(sid+1))
return sinfoHead->next
sinfoHead=sinfoHead->next
}
return NULL
}
void showSinfo(FLINFO *flinfo)//显示航班对应座位信息
{
SINFO *sinfoHead=flinfo->sHead,*sfp=NULL
int i,j,k,row=maxRow,clo=strlen(cID)
char typeStr[10]={0}
for(i=0i<rowi++)
{
//---------读取座位所属舱室------------
memset(typeStr,0,10)
for(k=0k<TYPESIZEk++)
if(i+1>=types[k][0] && i+1<=types[k][1])
strcpy(typeStr,typeName[k])
//--------------------------------------
printf("\n")
for(j=0j<cloj++)
printf("------------- ")
printf("\n")
sfp=sinfoHead
for(j=0j<cloj++)
{
printf("| %c%02d | ",sfp->next->cloID,sfp->next->row)
sfp=sfp->next
}
printf("\n")
sfp=sinfoHead
for(j=0j<cloj++)
{
printf("| %c | ",sfp->next->sell?2:1)
sfp=sfp->next
}
printf("\n")
sfp=sinfoHead
for(j=0j<cloj++)
{
printf("|%6s:%4.0f| ",typeStr,flinfo->tPrice*tDiscount[sfp->next->type]*timeDiscount)
sfp=sfp->next
}
printf("\n")
sinfoHead=sfp
}
for(j=0i<cloj++)
printf("------- ")
printf("\n")
}
FLINFO *selectFlinfo(FLINFO *flinfoHead,char *fid)//选择航班号,返回节点
{
while(flinfoHead->next)
{
if(!strcmp(flinfoHead->next->fid,fid))
return flinfoHead->next
flinfoHead=flinfoHead->next
}
return NULL
}
void printfFlinfo(FLINFO * flinfoHead)
{
while(flinfoHead->next)
{
printf("目的地:%s,航班号:%s\n----起飞时间:%s,抵达时间:%s\n\n",flinfoHead->next->toCity,flinfoHead->next->fid,getTString(localtime(&flinfoHead->next->tfTime)),getTString(localtime(&flinfoHead->next->ldTime)))
flinfoHead=flinfoHead->next
}
}
char *getTString(struct tm *tm0)//通过tm获取时间字符串
{
char *str=(char *)malloc(sizeof(char)*20),num[5]={0}
meError(str)
memset(str,0,20)
sprintf(num,"%4d",tm0->tm_year+1900)
strcat(str,num)
strcat(str,"-")
memset(num,0,5)
sprintf(num,"%02d",tm0->tm_mon)
strcat(str,num)
strcat(str,"-")
memset(num,0,5)
sprintf(num,"%02d",tm0->tm_mday)
strcat(str,num)
strcat(str," ")
memset(num,0,5)
sprintf(num,"%02d",tm0->tm_hour)
strcat(str,num)
strcat(str,":")
memset(num,0,5)
sprintf(num,"%02d",tm0->tm_min)
strcat(str,num)
strcat(str,":")
memset(num,0,5)
sprintf(num,"%02d",tm0->tm_sec)
strcat(str,num)
return str
}
time_t getTime_tfromStr(char *sTime)//将YYYY-MM-DD hh:mm:ss格式的时间字符串转换成time_t型数值
{
time_t rt
struct tm *tm1=NULL
rt=time(NULL)
tm1=localtime(&rt)
sscanf(sTime,("%4d-%2d-%2d %2d:%2d:%2d"),&tm1->tm_year,&tm1->tm_mon,&tm1->tm_mday,&tm1->tm_hour,&tm1->tm_min,&tm1->tm_sec)
tm1->tm_year-=1900
tm1->tm_mon--
rt=mktime(tm1)
return rt
}
FLINFO *initFlight()//初始化航班信息,返回航班链表头节点,如果想手动输入,请在这里添加!!!正常软件开发,这一步应该是从数据库读取!
{
FLINFO *ffHead=NULL,*flinfoTail=NULL,fNew
//--------添加一个航班信息----需要增加按照我下面调用方式写--------------------------------
strcpy(fNew.fid,"CI502")
fNew.tfTime=getTime_tfromStr("2019-02-20 03:30:30")
fNew.ldTime=getTime_tfromStr("2019-02-20 05:20:30")
strcpy(fNew.toCity,"台北")
fNew.tPrice=1000
fNew.next=NULL
flinfoTail=addFLINFO(&ffHead,flinfoTail,fNew)
//--------------------------------------------------------------------------------------------
strcpy(fNew.fid,"9C8921")
fNew.tfTime=getTime_tfromStr("2019-02-20 14:30:30")
fNew.ldTime=getTime_tfromStr("2019-02-20 16:40:30")
strcpy(fNew.toCity,"香港")
fNew.tPrice=500
fNew.next=NULL
flinfoTail=addFLINFO(&ffHead,flinfoTail,fNew)
return ffHead
}
FLINFO *addFLINFO(FLINFO **ffHead,FLINFO *flinfoTail,FLINFO fNew)//返回尾节点
//添加航班信息链表的节点flinfoHead:头节点(第一次传NULL会自动生成),flinfoTail:尾节点,fNew:要添加的结构信息(成员指针无需赋值)
{
FLINFO *flinfoHead=*ffHead
if(flinfoHead==NULL)
{
*ffHead=(FLINFO *)malloc(sizeof(FLINFO))
flinfoHead=*ffHead
meError(flinfoHead)
flinfoHead->next=NULL
}
FLINFO *flinfoNew=(FLINFO *)malloc(sizeof(FLINFO))
meError(flinfoNew)
flinfoNew->next=NULL
flinfoNew->fid[0]=0
strcpy(flinfoNew->fid,fNew.fid)
flinfoNew->ldTime=fNew.ldTime
flinfoNew->tfTime=fNew.tfTime
flinfoNew->toCity[0]=0
strcpy(flinfoNew->toCity,fNew.toCity)
flinfoNew->tPrice=fNew.tPrice
flinfoNew->sHead=getSINFO()
if(flinfoHead->next==NULL)
flinfoHead->next=flinfoNew
else
flinfoTail->next=flinfoNew
flinfoTail=flinfoNew
return flinfoTail
}
SINFO *getSINFO()//获取座位链表
{
int maxClo=strlen(cID),cnt=maxClo*maxRow,clo=0,row=1,i
SINFO *sinfoHead=(SINFO *)malloc(sizeof(SINFO)),*sinfoTail=NULL
meError(sinfoHead)
sinfoHead->next=NULL
SINFO *sinfoNew=NULL
while(cnt--)//按顺序生成对应数量的座位链表
{
if(clo==maxClo)
clo=0,row++
if(row==maxRow+1)
row=1
sinfoNew=(SINFO *)malloc(sizeof(SINFO))
meError(sinfoNew)
sinfoNew->cloID=cID[clo]
sinfoNew->row=row
for(i=0i<TYPESIZEi++)
if(row>=types[i][0] && row<=types[i][1])
{
sinfoNew->type=i
break
}
sinfoNew->sell=0
sinfoNew->next=NULL
if(sinfoHead->next==NULL)
sinfoHead->next=sinfoNew
else
sinfoTail->next=sinfoNew
sinfoTail=sinfoNew
clo++
}
return sinfoHead
}
void meError(void *p)//内存申请失败
{
if(p==NULL)
{
printf("\n异常:内存申请失败!回车结束程序!\n")
while(getch()!='\r')
exit(0)
}
}
1、任务:航空客运定票的业务活动包括:查询航线、客票预定和办理退票等。试设计一个航空客运定票系统,以使上述业务可以借助计算机来完成。2、功能要求:1) 录入:可以录入航班情况(数据可以存储在一个数据文件中,数据结构、具体数据自定)2) 查询:可以查询某个航线的情况(如,输入航班号,查询起降时间,起飞抵达城市,航班票价,票价折扣,确定航班是否满仓);可以输入起飞抵达城市,查询飞机航班情况;3) 订票:(订票情况可以存在一个数据文件中,结构自己设定)可以订票,如果该航班已经无票,可以提供相关可选择航班;4) 退票: 可退票,退票后修改相关数据文件;5) 客户资料:有姓名,证件号,订票数量及航班情况,订单要有编号;6) 修改航班信息:当航班信息改变可以修改航班数据文件。 3、要有一个好的界面~~~~~~~~~~~~~~~~~~~~~~~~4、需求分析系统需求(系统要求实现的功能的具体情况)5、 概要设计系统分析(分析系统的功能和具体模块的划分)系统流程(系统的流程图)程序详细代码:#include <stdio.h>#include <stdlib.h>
#include <string.h>
//#include <conio.h>
#define MAXSIZE 3
typedef struct wat_ros
{
char name[10]
int req_amt
struct wat_ros *next
}qnode,*qptr
typedef struct pqueue
{
qptr front
qptr rear
}linkqueue
typedef struct ord_ros
{
char name[10]
int ord_amt
int grade
struct ord_ros *next
}linklist
struct airline
{
char ter_name[10]/* 站点名 */
char air_num[10]/* 航班号 */
char plane_num[10]/* 飞机号 */
char date[7]/* 飞行日期 */
int tkt_amt/* 乘员定额 */
int tkt_sur/* 余票量 */
linklist *order
linkqueue wait
}lineinfo
struct airline *start
struct airline air[MAXSIZE]={
{"beijing", "1", "B8571", "SUN", 3, 1},
{"shanghai","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()
{
struct 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=start
printf("请输入终点站名:")
scanf("%s",name)
while(i<MAXSIZE)
{
if(!strcmp(name,info->ter_name)) break
info++
i++
}
if(i>=MAXSIZE)
printf("对不起,该航线未找到!\n")
else
{
printf("终点站名\t航班号\t飞机号\t飞行日期\t乘员定额\t余票量\n")
display(info)
}
}
struct airline *find()
{
struct airline *info
char number[10]
int i=0
info=start
printf("请输入航班号:")
scanf("%s",number)
while(i<MAXSIZE)
{
if(!strcmp(number,info->air_num)) return info
info++
i++
}
printf("对不起,该航线末找到!\n")
return NULL
}
/* 浏览已订票客户信息 */
void prtlink()
{
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 *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)
{head=new1new1->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
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<=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=0i<amounti++)
printf("%s的座位号是:%d\n",name,info->tkt_amt-info->tkt_sur+i+1)
info->tkt_sur-=amount
printf("\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欢迎您下次再次订购!\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)) break
p2=p1p1=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
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=0i<t->req_amti++)
printf("%s的座位号是:%d\n",t->name,(info->tkt_sur)-i)
info->tkt_sur-=t->req_amt
info->order=insertlink(info->order,t->req_amt,t->name,grade)
free(t)
break
}
back=tt=t->next
if((info->tkt_sur)>=(t->req_amt)&&t!=NULL)
{ int i
back->next=t->next
printf("%s订票成功!\n",t->name)
for(i=0i<t->req_amti++)
printf("<%s>'s seat number is:%d\n",t->name,(info->tkt_sur)-i)
info->tkt_sur-=t->req_amt
info->order=insertlink(info->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_surp++)
for(q=p+1q->tkt_surq++)
{
if(p->tkt_sur<q->tkt_sur)
{
t=*p
*p=*q
*q=t
}
}
printf("终点站名\t航班号\t飞机号\t飞行日期\t乘员定额\t余票量\n")
for(j=0j<MAXSIZEj++)
{
display(info)
info++
}
}
int menu_select()
{
int c
char s[20]
printf("\n\t\t 航空客运订票系统(by zjhxmjl)\n")
printf(" ******************************************\n")
printf(" ** 1.浏览航线信息 **\n")
printf(" ** 2.浏览已订票客户信息 **\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(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
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
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)