#include <string.h>
#include <conio.h>
#include <ctype.h>
#include <stdlib.h>
#include <malloc.h>
#include <math.h>//overflow
#define ok 1
typedef struct Yidingkehu
{//单链表
char name[15]//已订票的客户姓名
int dingpiaoshu//已订票数量
struct Yidingkehu *next1//
}Yidingkehu,*Link
typedef struct Weidingkehu
{//单链队
char name[15]//预订票的客户姓名
int yudingpiao// 要订票数量
struct Weidingkehu *next2//下一个链队结点指针
}Weidingkehu,*Qptr
typedef struct Hangxian
{//创建一个含有六个信息的结构体
char hangbanhao[15]//航班号-
char feijihao[15]//飞机号
int feixingriqi//起飞时间镇烂尺
int chenkerenshu//座位数
int yupiao//余票
char zhongdianzhai[15]//降落城市
struct Hangxian *next//指向下一个链结点的指针
struct Yidingkehu *yiding//定义一个指向已订票客户的头结点指针
struct Weidingkehu *yudingqueue
}Hangxian,*Linklist
Linklist InitLinklist()//01
int InsertLinklist(Linklist &head1)//02
void hbhchaxun()//通过航班号查询
void mddchaxun()//通过目的地查询
void lurugongneng()//初始化录入功能
void chaxungongnen()//查询功能
void dingpiaogongnen()//订票功能
void tuipiaogongnen()//退票功能
void main()
{
int n
do{ //打印主界面
printf("\t 欢迎使用航空客运订票系统\n")
printf("\t+++++++++++++++++++++++++++++\n")
printf("\t==>1. 录入功能 ==\n")
printf("\t==>2. 查询功能 ==\n")
printf("\t==>3. 订票功能 ==\n")
printf("御高\t==>4. 退票功能 ==\n")
printf("\t==>5. 退出 ==\n")
printf("\t+++++++++++++++++++++++++++++\n")
printf("\t请选择:")
scanf("%d",&n)printf("\n")
switch(n)
{
case 1: lurugongneng()//录入功能
break
case 2: chaxungongnen()//查询功能
break
case 3: dingpiaogongnen()//订票功能
break
case 4:tuipiaogongnen()/历橘/退票功能
break
default :exit(0)//退出
}
}while(n==1||n==2||n==3||n==4)
}
void lurugongneng()//初始化的单链表*********************************************************录入功能
{
Linklist p
//int m,n
if(!p) exit(OVERFLOW)
printf("\t请依次输入下面几项内容:\n\n")//这里的输入采用一个个单独输入,避免了乱赋值的现象
printf("航班号\n")
gets(p->hangbanhao)//这里的二个gets主要是因为在回车键的输入,其中的第一个是来接收上次的回车
gets(p->hangbanhao)
printf("飞机号\n")
gets(p->feijihao)
printf("终点站\n")
gets(p->zhongdianzhai)
printf("飞行日期\n")
scanf("%d",&p->feixingriqi)
printf("乘客总数\n")
scanf("%d",&p->chenkerenshu)
printf("余票数\n")
scanf("%d",&p->yupiao)
}
void chaxungongnen()//******************************************************************查询功能
{
int n
printf("\t 查 找 航 线 信 息 \n")
printf("\t+++++++++++++++++++++++++++++\n")
printf("\t==>1. 通过目的地查询 ==\n")
printf("\t==>2. 通过航班号查询 ==\n")
printf("\t+++++++++++++++++++++++++++++\n")
printf("\t请选择:")
scanf("%d",&n)
printf("\n")//格式化
switch(n)
{
case 1:mddchaxun()
break
case 2:hbhchaxun()
break
default :break
}
}
void mddchaxun()//通过目的地查询
{
char c[15]
int m
Linklist p=L
printf("\t请输入要查询的目的地:")
gets(c)
gets(c)//原因同上
do{
p=p->next
if(p)
{
m=strcmpi((*p).zhongdianzhai,c)//如果==的话则m=0
if(m==0)
{
printf("\t航班信息:\n")
printf("\t航班号:%s\n",p->hangbanhao)
printf("\t飞机号:%s\n",p->feijihao)
printf("\t飞行时间:周%d\n",p->feixingriqi)
printf("\t余票量:%d\n",p->yupiao)
}
}
else
{//如果不匹配的话就做
printf("\t对不起没有你要找的目的地:\n\n")m=0
}
}while(m!=0)
}
void hbhchaxun()//通过目的地查询
{
char c[15]
int m
Linklist p=L
printf("\t请输入要查询的航班号:")
gets(c)gets(c)printf("\n")
do{
p=p->next
if(p)
{
m=strcmpi((*p).hangbanhao,c)//如果==的话则m=0这里的(*p).与p->的作用是一样的
if(m==0)
{
printf("\t航班信息:\n")
printf("\t航班号:%s\n",p->hangbanhao)
printf("\t飞机号:%s\n",p->feijihao)
printf("\t飞行时间:周%d\n",p->feixingriqi)
printf("\t余票量:%d\n\n",p->yupiao)
}
}
else
{//如果不匹配的话就做
printf("\t对不起没有你要找的航班号:\n")m=0
}
}while(m!=0)
}
void dingpiaogongnen()//***************************************************************订票功能
{
char c[15]
int m=1,piao,ydpiao=0,yd=0,n//
gets(c)
printf("请输入终点站名:")gets(c)printf("\n")
p=L->next
if(p) {
do{//查找一下,是否有这个航班
if(!p)
{
printf("对不起,没有你要找的航班:\n\n")
goto loop1
}
m=strcmpi(p->zhongdianzhai,c)
if(m==0)
{
printf("航班信息:\n")
printf("航班号:%s\n",p->hangbanhao)
printf("飞机号:%s\n",p->feijihao)
printf("飞行时间:周%d\n",p->feixingriqi)
printf("余票量:%d\n",p->yupiao)}
else p=p->next
}while(m!=0)
if(m==0)
{
do{
printf("\n请输入你要订的票数:")scanf("%d",&piao)
if(piao<=p->yupiao)
{
h=p->yiding
if(h)
{
h1=h
h=h->next1
h=(struct Yidingkehu*)malloc(sizeof(Yidingkehu))
printf("请输入你的名字:")
gets(h->name)gets(h->name)
h->dingpiaoshu=piao
h->next1=h1->next1
h1->next1=h
p->yupiao=p->yupiao-piao
printf("订票成功:\n")m=2
}
}
else
{
printf("余票量:%d\n",p->yupiao)
printf("对不起,余票 %d 张不足,不能完成订票\n\n",p->yupiao)
printf(" 是否要重新订票?\n")
printf("需要请输入1 否则请按2 预订请输入3 : ")
scanf("%d",&m)
printf("\n")
if(m==3) goto loop3
}
}while(m==1)
}
}
else if(!p)
{
loop3: struct Weidingkehu *q3
printf("对不起,该航班的票已售完\n")
q.front=p->yudingqueue
if(q.front==q.rear) printf("没有人预订票,是否要预订?\n")
else if(q.front!=q.rear) printf("已有人预订票,是否要预订?\n")
printf("预订请输入1 否则输入2 : ")
scanf("%d",&n)
printf("\n")
if(n==1)
{
printf("请输入你的姓名")gets(q3->name)gets(q3->name)//q3不能指向name???
printf("请输入订票数")scanf("%d",&q3->yudingpiao)
q3->next2=NULL
q.rear->next2=q3
q.rear=q3
printf(" 你已经预订了 !\n")
}
}
loop1:
}
void tuipiaogongnen()//***************************************************************退票功能
{
}
请采纳答案,支持我一下。
(已修改,请用最新的代码)代码说明:
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)
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)