用c语言写个火车票订票系统

时间: 2023-11-22 08:53:51 浏览: 102
好的,下面是一个简单的火车票订票系统的C语言代码示例: ``` #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_TRAIN_NUM 100 #define MAX_SEAT_NUM 100 struct Train { char name[50]; int seats[MAX_SEAT_NUM]; }; struct Train trains[MAX_TRAIN_NUM]; int trainNum = 0; void addTrain(char* name, int* seats, int seatNum) { if (trainNum >= MAX_TRAIN_NUM) { printf("The maximum number of trains has been reached.\n"); return; } struct Train train; strcpy(train.name, name); for (int i = 0; i < seatNum; i++) { train.seats[i] = seats[i]; } trains[trainNum] = train; trainNum++; printf("Train added successfully.\n"); } void bookTicket(int trainIndex, int seatNum) { if (trainIndex < 0 || trainIndex >= trainNum) { printf("Invalid train index.\n"); return; } struct Train train = trains[trainIndex]; if (seatNum < 0 || seatNum >= MAX_SEAT_NUM) { printf("Invalid seat number.\n"); return; } if (train.seats[seatNum] == 0) { printf("The seat is already booked.\n"); return; } train.seats[seatNum] = 0; trains[trainIndex] = train; printf("Ticket booked successfully.\n"); } void showTrainInfo(int trainIndex) { if (trainIndex < 0 || trainIndex >= trainNum) { printf("Invalid train index.\n"); return; } struct Train train = trains[trainIndex]; printf("Train Name: %s\n", train.name); printf("Total Seats: %d\n", sizeof(train.seats) / sizeof(int)); printf("Available Seats:\n"); for (int i = 0; i < sizeof(train.seats) / sizeof(int); i++) { if (train.seats[i] != 0) { printf("%d ", i+1); } } printf("\n"); } void showAllTrains() { printf("Total Trains: %d\n", trainNum); printf("Train List:\n"); for (int i = 0; i < trainNum; i++) { printf("%d. %s\n", i+1, trains[i].name); } } int main() { int choice; do { printf("\nWelcome to Train Ticket Booking System\n"); printf("1. Add Train\n"); printf("2. Book Ticket\n"); printf("3. Show Train Info\n"); printf("4. Show All Trains\n"); printf("5. Exit\n"); printf("Enter your choice: "); scanf("%d", &choice); switch (choice) { case 1: { char name[50]; int seatNum; printf("Enter train name: "); scanf("%s", name); printf("Enter number of seats: "); scanf("%d", &seatNum); int seats[MAX_SEAT_NUM]; for (int i = 0; i < seatNum; i++) { seats[i] = i + 1; } addTrain(name, seats, seatNum); break; } case 2: { int trainIndex, seatNum; printf("Enter train index: "); scanf("%d", &trainIndex); printf("Enter seat number: "); scanf("%d", &seatNum); bookTicket(trainIndex - 1, seatNum - 1); break; } case 3: { int trainIndex; printf("Enter train index: "); scanf("%d", &trainIndex); showTrainInfo(trainIndex - 1); break; } case 4: { showAllTrains(); break; } case 5: { exit(0); } default: { printf("Invalid choice.\n"); break; } } } while (1); return 0; } ``` 这个程序中,我们定义了一个结构体 `Train`,其中包含火车名称和座位数组。然后我们使用数组来存储火车信息,可以添加火车、订票、查看火车信息和列出所有火车的列表。

相关推荐

最新推荐

recommend-type

软件课程设计--C语言设计火车票订票系统之源代码(模拟数据库功能)(需求分析+可行性分析)

软件课程设计--C语言设计火车票订票系统之源代码(模拟数据库功能)(需求分析+可行性分析)
recommend-type

c语言课程设计(车票管理系统)

该系统主要对火车进行管理,包括录入、显示、修改、查询、订票,退票、删除、保存等操作。
recommend-type

鸡国大冒险运行程序,点开即用

recommend-type

基于Python+Flask的安全多方计算的隐私保护系统设计与实现+全部资料齐全+部署文档.zip

【资源说明】 基于Python+Flask的安全多方计算的隐私保护系统设计与实现+全部资料齐全+部署文档.zip基于Python+Flask的安全多方计算的隐私保护系统设计与实现+全部资料齐全+部署文档.zip 【备注】 1、该项目是个人高分项目源码,已获导师指导认可通过,答辩评审分达到95分 2、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 3、本项目适合计算机相关专业(人工智能、通信工程、自动化、电子信息、物联网等)的在校学生、老师或者企业员工下载使用,也可作为毕业设计、课程设计、作业、项目初期立项演示等,当然也适合小白学习进阶。 4、如果基础还行,可以在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!
recommend-type

聊天系统(java+applet).zip

聊天系统(java+applet)
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。