资源简介
模拟一个飞机票订票和退票系统假定某民航机场有m个航次的班机,每个航次都只到达一个目的地。试为该机场售票处设计一个自动订票和退票系统。要求系统具有下列功能:(1) 订票。若该航次余票数大于等于乘客订票数,则在该航次的乘客表(按乘客姓氏字母顺序连接)中,插入订票乘客的信息项,并修改航次有关数据,否则,给出相应的提示信息。(2) 退票。若该航次当前退票数小于等于乘客订票数,则在相应的乘客表中找到该乘客项,修改该航次及乘客表中的有关数据.当由于退票,使乘客的订票数为零时,要从乘客表中撤消该乘客项;否则,给出相应的提示信息.(3) 将某航次的余票数恢复初值------该航次的最大客票数.当客户订票数要求不能满足时,系统也可向客户提供到达同一目的地的其他航线情况.
代码片段和文件信息
#include
#include
#include
#include
using namespace std;
#define MaxNode 100
#define charl 100
#define MaxContainf 100
int m;//航班的次数
typedef struct TypeTime
{
int hour;
int minute;
int TimeLong;
}TypeTime;
typedef struct Passenger
{
char name[charl];
int TicketNum;
struct Passenger *next;
}Passenger;
typedef struct TypeFight
{
TypeTime StartTime;
TypeTime EndTime;
int MaxContain;
int ReadyContain;
Passenger *head;
Passenger *last;
}TypeFight;
typedef struct TypePlane
{
char ID[charl];
char StartPlace[charl];
char EndPlace[charl];
int PlaneNum;
TypeFight PlaneFight[MaxNode];
}TypePlane;
TypePlane Plane[MaxNode];
/*int rand01()
{
//随机产生01
srand( (unsigned)time( NULL ) );
return rand() % 2;
}*/
void newline(int n)
{
int i;
for(i = 1;i <= n;i++)
printf(“\n“);
}
void space(int n)
{
int i;
for(i = 1;i <= n;i++)
printf(“ “);
}
void Input()
{
//初始输入输入
FILE *fp;
int i j;
//freopen(“outt.txt“ “w“ stdout);
fp = fopen(“plane.txt“ “r“);
fscanf(fp “%d“ &m);
printf(“m = %d\n“ m);
for(i = 0;i < m;i++){
fscanf(fp “%s%s%s%d“ Plane[i].StartPlacePlane[i].EndPlace
Plane[i].ID &Plane[i].PlaneNum);
printf(“%s %s\n%s\n%d\n“ Plane[i].StartPlace Plane[i].EndPlace
Plane[i].ID Plane[i].PlaneNum);
for(j = 0;j < Plane[i].PlaneNum;j++){
fscanf(fp “%d:%d“ &Plane[i].PlaneFight[j].StartTime.hour
&Plane[i].PlaneFight[j].StartTime.minute);
fscanf(fp “%d:%d“ &Plane[i].PlaneFight[j].EndTime.hour
&Plane[i].PlaneFight[j].EndTime.minute);
printf(“%d:%d “ Plane[i].PlaneFight[j].StartTime.hour
Plane[i].PlaneFight[j].StartTime.minute);
printf(“%d:%d\n“ Plane[i].PlaneFight[j].EndTime.hour
Plane[i].PlaneFight[j].EndTime.minute);
Plane[i].PlaneFight[j].MaxContain = MaxContainf;
Plane[i].PlaneFight[j].ReadyContain = 0;
Plane[i].PlaneFight[j].StartTime.TimeLong =
Plane[i].PlaneFight[j].StartTime.hour * 60 +
Plane[i].PlaneFight[j].StartTime.minute;
Plane[i].PlaneFight[j].EndTime.TimeLong =
Plane[i].PlaneFight[j].EndTime.hour * 60 +
Plane[i].PlaneFight[j].EndTime.minute;
Plane[i].PlaneFight[j].head = (Passenger *)malloc(sizeof(Passenger));
Plane[i].PlaneFight[j].head->next = NULL;
Plane[i].PlaneFight[j].last = Plane[i].PlaneFight[j].head;
}
}
fclose(fp);
}
int BookTicket()
{
char ID[charl];
char name[charl];
TypeTime BeforeTime;
int TimeLong Remain;
int i j TicketNum;
int flag = 0;
int n;
Passenger *p *s *t;
while(1){
system(“cls“);
printf(“请输入你要都买得的票的ID。。。。\n“);
scanf(“%s“ ID);
for(i = 0;i < m;i++){
if(strcmp(Plane[i].ID ID) == 0)break;
}
if(i >= m) return 0; //查询失败,找不到你要查找的
- 上一篇:人员信息管理系统c++版超详细
- 下一篇:MFC CComboBox 实现自动补全
相关资源
- C++Primer第五版---高清版.zip
- 维吉尼亚密码的简单实现
- 从放弃C语言到使用C刷算法的简明教程
- vc6.0上位机教程.docx
- VisualC++范例大全源代码+PDF_百度云盘地
- C++游戏服务器开发从入门到掌握.txt
- C++2017.txt
- 02_C++PrimerPlus_中文版_第6版_超清.txt
- c语言学习例题.docx
- 源.cpp
- Steffensen.cpp
- vc++著名的木马程序BO2000源代码.rar
- 语音信号端点检测(VC++6.0)
- zw_duanzhiying-1870490-C语言库函数.zip
- zw_RSA算法C语言实现.zip
- zw_MFCCombox自动提示.zip
- 视觉识别特定草莓等其他水果
- welch功率谱的c语言程序.txt
- 蓝桥杯青少组C++赛前集训包.pdf
- L.CPP
- c++primer_第五版_中文版(完整).rar
- test_opencv.cpp
- CC语言程序设计课后答案.doc
- C语言程序设计KANDR版.pdf
- dft.cpp
- cc++项目视频.txt
- sanke.cpp
- iar.cc++.compiler.v1.30.3.50673.for.rl78-patch
- dos.cpp
- 红外避障小车程序C语言源码.rar
评论
共有 条评论