C++實(shí)現(xiàn)航空訂票程序
本文實(shí)例為大家分享了C++實(shí)現(xiàn)航空訂票程序的具體代碼,供大家參考,具體內(nèi)容如下
這是幫我同學(xué)寫的一個(gè)C++作業(yè),說實(shí)話好久沒寫過C++都有些生疏了。但他們好像還沒學(xué)面向?qū)ο缶幊?,所以只能是?jiǎn)單的結(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ù),簡(jiǎn)化我們的代碼,這里之所以將輸入提取成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ù)非常簡(jiǎn)單,首先需要將座位和票信息初始化,即將它們編號(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é)寫的,要是你們都一樣,豈不要尷尬了。
以上就是本文的全部?jī)?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-04C語言 動(dòng)態(tài)內(nèi)存分配的詳解及實(shí)例
這篇文章主要介紹了C語言 動(dòng)態(tài)內(nèi)存分配的詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下2016-09-09C++實(shí)現(xiàn)LeetCode(86.劃分鏈表)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(86.劃分鏈表),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++實(shí)現(xiàn)學(xué)生考勤信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)學(xué)生考勤信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12C++圖論之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-06Visual?Studio?2022下載安裝與使用超詳細(xì)教程
這篇文章主要介紹了Visual?Studio?2022最新版安裝與使用教程,本文以社區(qū)版為例通過圖文并茂的形式給大家介紹Visual?Studio?2022安裝使用,需要的朋友可以參考下2022-04-04C++實(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