C++實(shí)現(xiàn)航空訂票程序
本文實(shí)例為大家分享了C++實(shí)現(xiàn)航空訂票程序的具體代碼,供大家參考,具體內(nèi)容如下
這是幫我同學(xué)寫的一個(gè)C++作業(yè),說實(shí)話好久沒寫過C++都有些生疏了。但他們好像還沒學(xué)面向?qū)ο缶幊蹋灾荒苁呛唵蔚慕Y(jié)構(gòu)體和輸入輸出的邏輯。
題目要求:
編寫一個(gè)航空訂票程序:
假設(shè)一等艙5個(gè)座位,編號(hào)為1~5,經(jīng)濟(jì)艙20個(gè)座位,編號(hào)為1~20
具體要求如下:
當(dāng)程序開始時(shí),提示輸入乘客姓名,一個(gè)名字只能訂一個(gè)座位,如果該名字已經(jīng)訂過座位了,則提示該乘客座位已定及座位號(hào),否則提示輸入艙位類型;
當(dāng)輸入艙位類型后,如果該艙位已全部訂出,則提示此艙全部訂完,重新選擇艙位類型;否則顯示可以選擇的座位號(hào),注意已經(jīng)被訂出的座位號(hào)不能出現(xiàn),提示輸入座位號(hào);
艙位類型:只能輸入”F”或”E”,一等艙為F,經(jīng)濟(jì)艙為E,如果輸入其它字符則提示輸入無效。
座位號(hào):只能輸入前面列出可以選擇的座位號(hào),若輸入其它則提示輸入無效。
程序可以為多個(gè)乘客訂票,直到輸入名字為”.”;
最后程序按照艙位類型與座位號(hào)排序打印出所有訂票信息(座位號(hào)及對(duì)應(yīng)乘客姓名)
最終實(shí)現(xiàn)效果:

1、變量
不過既然提到了結(jié)構(gòu)體用來存儲(chǔ)票的信息(其實(shí)這就是面向?qū)ο笏枷氲脑缙冢?。?lián)系實(shí)際,一個(gè)結(jié)構(gòu)體代表一個(gè)事物,結(jié)構(gòu)體中的字段代表這個(gè)事物的屬性;這樣的話,我們可以提取出兩個(gè)結(jié)構(gòu)體:座位Seat和票Ticket,由于題目給定總共25個(gè)座位,意味著25張票,則將它們聲明成全局變量。
//座位,那么座位有3個(gè)基本屬性:座位類型(F/E),座位編號(hào),座位預(yù)定狀態(tài)(是否已經(jīng)被預(yù)定)
struct Seat{
char type;
int number;
bool isReservation;
}seats[25];
//票,票有兩個(gè)屬性,即票需要表明:誰預(yù)定了哪個(gè)座位,第一個(gè)Seat就是我們前面定義的那個(gè)結(jié)構(gòu)體。
struct Ticket{
Seat seat;
string passenger_name;
}tickets[25];
2、函數(shù)
我們需要將一些輸出輸入的操作提取成函數(shù),簡化我們的代碼,這里之所以將輸入提取成input()函數(shù),是因?yàn)槲覀冃枰粩噍斎?,即使出錯(cuò),所以為了便于遞歸調(diào)用就封裝成函數(shù);
bool check(string name);//檢測(cè)是否已購票 void input();//用于執(zhí)行輸入 void printSeat(char seatType);//顯示剩余座位 void reservation(string name,int seatNumber,char seatType);//購票 void printTickets(string name);//顯示已購票信息 void printError();//顯示輸入不合法
3、主體邏輯
main函數(shù)非常簡單,首先需要將座位和票信息初始化,即將它們編號(hào),預(yù)定狀態(tài)全為“未預(yù)定”,然后執(zhí)行輸入,一個(gè)while循環(huán),如果不符合條件就直接跳出while,執(zhí)行printTickets()打印出所有的訂票信息;
int main()
{
//初始化艙位和票
for(int i=0;i<25;i++){
if(i<5){
seats[i].type='F';
seats[i].number=i+1;
}else{
seats[i].type='E';
seats[i].number=i+1-5;
}
seats[i].isReservation=false;
tickets[i].seat=seats[i];
tickets[i].passenger_name=" ";
}
cout<<"================================================="<<endl;
cout<<" 歡迎使用CT票務(wù)系統(tǒng) "<<endl;
cout<<"================================================="<<endl;
cout<<"乘客姓名:";
while(cin>>name){
if(name==".")break;
if(surplusF+surplusE==0){
cout<<"\n很遺憾所有票已購?fù)?!\n";
break;
}
if(check(name)){
cout<<"\n您已購票,購票信息:\n"<<endl;
printTickets(name);
}else{
cout<<"\n艙位類型 F:一等艙 E:經(jīng)濟(jì)艙\n";
input();
}
cout<<"\n乘客姓名:";
}
printTickets("");
return 0;
}
4、具體函數(shù)實(shí)現(xiàn)
具體的函數(shù)實(shí)現(xiàn)邏輯我就不講了,就看代碼吧~
5、完整代碼:
main.cpp
#include<iostream>
using namespace std;
//定義全局變量,艙位,票,各類型艙位剩余數(shù),便于其它函數(shù)全局訪問
int surplusF=5;
int surplusE=20;
int flag=0;
char seat_type;
int seatNumber;
string name;
//座位
struct Seat{
char type;
int number;
bool isReservation;
}seats[25];
//票
struct Ticket{
Seat seat;
string passenger_name;
}tickets[25];
bool check(string name);//檢測(cè)是否已購票
void input();//用于執(zhí)行輸入
void printSeat(char seatType);//顯示剩余座位
void reservation(string name,int seatNumber,char seatType);//購票
void printTickets(string name);//顯示已購票信息
void printError();//顯示輸入不合法
int main()
{
//初始化艙位和票
for(int i=0;i<25;i++){
if(i<5){
seats[i].type='F';
seats[i].number=i+1;
}else{
seats[i].type='E';
seats[i].number=i+1-5;
}
seats[i].isReservation=false;
tickets[i].seat=seats[i];
tickets[i].passenger_name=" ";
}
cout<<"================================================="<<endl;
cout<<" 歡迎使用CT票務(wù)系統(tǒng) "<<endl;
cout<<"================================================="<<endl;
cout<<"乘客姓名:";
while(cin>>name){
if(name==".")break;
if(surplusF+surplusE==0){
cout<<"\n很遺憾所有票已購?fù)辏n";
break;
}
if(check(name)){
cout<<"\n您已購票,購票信息:\n"<<endl;
printTickets(name);
}else{
cout<<"\n艙位類型 F:一等艙 E:經(jīng)濟(jì)艙\n";
input();
}
cout<<"\n乘客姓名:";
}
printTickets("");
return 0;
}
bool check(string name)
{
for(int i=0;i<25;i++){
if(name==tickets[i].passenger_name)
return true;
}
return false;
}
//負(fù)責(zé)輸入,之所以單獨(dú)寫成函數(shù),是因?yàn)榉欠ㄝ斎氲臅r(shí)候需要遞歸調(diào)用
void input()
{
flag=0;
cout<<"\n艙位類型(F/E):";
cin>>seat_type;
cin.get();
switch(seat_type){
case 'F':
if(surplusF>0)
cout<<"\n可選座位號(hào):";
printSeat('F');
if(flag!=0)break;
cin>>seatNumber;
cin.get();
reservation(name,seatNumber,'F');
break;
case 'E':
if(surplusE>0)
cout<<"\n可選座位號(hào):";
printSeat('E');
if(flag!=0)break;
cin>>seatNumber;
cin.get();
reservation(name,seatNumber,'E');
break;
default:
printError();
input();
break;
}
}
//輸出可選的座位號(hào)
void printSeat(char seatType)
{
int full=0;
for(int i=0;i<25;i++){
if(seats[i].isReservation==false){
if(seatType=='F'){
if(surplusF==0){
cout<<"\n此艙位全部訂完,請(qǐng)重新選擇艙位類型:\n";
full++;
break;
}
cout<<seats[i].number<<" ";
if(i==4) break;
}
if(seatType=='E'){
if(surplusE==0){
cout<<"\n此艙位全部訂完,請(qǐng)重新選擇艙位類型:\n";
full++;
break;
}
if(i>4){
cout<<seats[i].number<<" ";
}
}
}
}
if(full==0){
cout<<"\n";
cout<<"\n座位號(hào):";
}else{
input();
flag++;
}
}
//輸入無效
void printError()
{
cout<<"\n輸入無效!"<<endl;
}
//購票,即改變seats tickets 屬性值
void reservation(string name,int seatNumber,char seatType)
{
if(seatNumber<1&&seatNumber>20){
printError();
}
else{
switch(seatType){
case 'F':
if(seatNumber>0&&seatNumber<6){
if(seats[seatNumber-1].isReservation==false){
seats[seatNumber-1].isReservation=true;
tickets[seatNumber-1].seat=seats[seatNumber-1];
tickets[seatNumber-1].passenger_name=name;
surplusF--;
cout<<"\n 恭喜 "+name+" 訂票成功!"<<endl;
break;
}else{
printError();
//input();
}
}else
printError();
break;
case 'E':
if(seatNumber>0&&seatNumber<=20){
if(seats[seatNumber+4].isReservation==false){
seats[seatNumber+4].isReservation=true;
tickets[seatNumber+4].seat=seats[seatNumber+4];
tickets[seatNumber+4].passenger_name=name;
surplusE--;
cout<<"\n 恭喜 "+name+" 訂票成功!"<<endl;
break;
}else{
printError();
}
}else
printError();
break;
}
}
}
void printTickets(string name)
{
cout<<"================================================="<<endl;
cout<<" 訂 票 信 息 "<<endl;
cout<<"================================================="<<endl;
cout<<" 艙位類型 座位號(hào) 乘客姓名 "<<endl;
cout<<"\n";
for(int i=0;i<25;i++){
if(name==tickets[i].passenger_name){
switch(tickets[i].seat.type){
case 'F':
cout<<" 頭等艙 ";
break;
case 'E':
cout<<" 經(jīng)濟(jì)艙 ";
break;
}
cout<<tickets[i].seat.number<<" "<<tickets[i].passenger_name<<endl;
cout<<"\n";
break;
}
else if(name==""){
if(tickets[i].seat.isReservation==true){
switch(tickets[i].seat.type){
case 'F':
cout<<" 頭等艙 ";
break;
case 'E':
cout<<" 經(jīng)濟(jì)艙 ";
break;
}
cout<<tickets[i].seat.number<<" "<<tickets[i].passenger_name<<endl;
cout<<"\n";
}
}
}
cout<<"================================================="<<endl;
}
Tips:
如果某些偷懶的家伙正好是做這個(gè)課程大作業(yè)搜到這兒了,希望你能在看懂的基礎(chǔ)上自己多改改,畢竟這是我替同學(xué)寫的,要是你們都一樣,豈不要尷尬了。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++與namespace有關(guān)的兩個(gè)編譯錯(cuò)誤的講解
今天小編就為大家分享一篇關(guān)于C++與namespace有關(guān)的兩個(gè)編譯錯(cuò)誤的講解,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-04-04
C語言 動(dòng)態(tài)內(nèi)存分配的詳解及實(shí)例
這篇文章主要介紹了C語言 動(dòng)態(tài)內(nèi)存分配的詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2016-09-09
C++實(shí)現(xiàn)LeetCode(86.劃分鏈表)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(86.劃分鏈表),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++實(shí)現(xiàn)學(xué)生考勤信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)學(xué)生考勤信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
C++圖論之Bellman-Ford算法和SPFA算法的實(shí)現(xiàn)
貝爾曼-福特算法(Bellman-Ford)是由理查德·貝爾曼和萊斯特·福特創(chuàng)立的,求解單源最短路徑問題的一種算法。SPFA 算法是 Bellman-Ford算法 的隊(duì)列優(yōu)化算法的別稱,通常用于求含負(fù)權(quán)邊的單源最短路徑。本文將詳解兩個(gè)算法的實(shí)現(xiàn),需要的可以參考一下2022-06-06
Visual?Studio?2022下載安裝與使用超詳細(xì)教程
這篇文章主要介紹了Visual?Studio?2022最新版安裝與使用教程,本文以社區(qū)版為例通過圖文并茂的形式給大家介紹Visual?Studio?2022安裝使用,需要的朋友可以參考下2022-04-04
C++實(shí)現(xiàn)WebSocket服務(wù)器的案例分享
WebSocket是一種在單個(gè)TCP連接上進(jìn)行全雙工通信的通信協(xié)議,與HTTP協(xié)議不同,它允許服務(wù)器主動(dòng)向客戶端發(fā)送數(shù)據(jù),而不需要客戶端明確地請(qǐng)求,本文主要給大家介紹了C++實(shí)現(xiàn)WebSocket服務(wù)器的案例,需要的朋友可以參考下2024-05-05

