這篇文章給大家分享的是有關使用C++實現(xiàn)商品管理程序的案例的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
成都創(chuàng)新互聯(lián)公司堅持“要么做到,要么別承諾”的工作理念,服務領域包括:網(wǎng)站設計制作、成都網(wǎng)站建設、企業(yè)官網(wǎng)、英文網(wǎng)站、手機端網(wǎng)站、網(wǎng)站推廣等服務,滿足客戶于互聯(lián)網(wǎng)時代的潯陽網(wǎng)站設計、移動媒體設計的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡建設合作伙伴!一、題目:商品管理程序
二、目的與要求
1.目的
培養(yǎng)學生綜合利用C++語言進行程序設計的能力,培養(yǎng)學生綜合利用C++語言進行程序設計的能力,熟悉數(shù)組的操作,加強函數(shù)的運用,掌握典型算法的使用,提高軟件系統(tǒng)分析能力和程序文檔建立、歸納總結(jié)的能力。
2.基本要求
(1) 要求用C++語言編程,在Visual C++環(huán)境下調(diào)試完成;
(2) 要求按照程序功能分成幾個功能模塊來實現(xiàn),各個功能模塊分別使用函數(shù)來完成;
(3) 要求提供操作菜單,以便用戶進行選擇;
(4) 應對程序添加必要的注釋;
(5) 要求應用本課所講授的程序設計語言知識來解決問題,使用教材前六章的內(nèi)容來完成程序。
3.創(chuàng)新要求
在基本要求達到后,進行創(chuàng)新設計:
(1) 對程序功能進行拓展,使其更加實用。例如增加刪除功能和插入功能,即找到指定商品后將其從原數(shù)組中刪除;將新商品的信息按照商品代碼升序的順序插入到原數(shù)組中。
三、設計方法和基本原理
1.1功能描述
編寫一個簡單的商品信息管理程序,主要完成商品的一些信息的計算,商品的排序、查詢及顯示功能。
問題詳細描述
某商場的電器區(qū)有多種商品,每種商品包括以下信息:
代碼(整型),名稱(字符串),總量(整型),單價(雙精度),銷售量(整型),庫存量(=總量-銷售量,整型),銷售額(銷售量*單價,雙精度),例如目前有五種商品的基本信息,如表1所示。
--------------------------------------表1 商品信息列表-----------------------------------------------
要求在主函數(shù)中對各類商品的信息進行初始化,編寫多個函數(shù)分別實現(xiàn)下列功能,而后在main函數(shù)中進行調(diào)用。
各個函數(shù)的功能描述為:
(1) 計算函數(shù)cal:計算各類商品的庫存量及銷售額。
(2) 排序函數(shù)sort1:按庫存量升序排序,若庫存量相同則按銷售量升序排序,要求使用冒泡法排序。
(3) 排序函數(shù)sort2:按商品名稱降序排序,要求使用選擇法排序。
(4) 查詢函數(shù)search:根據(jù)商品代碼查找指定商品。若找到則返回該商品的下標,否則返回-1。
(5) 匯總函數(shù)total:計算并返回銷售總額(所有商品的銷售額的和)。
(6) 顯示函數(shù)output:輸出商品的信息。
(7) 顯示菜單函數(shù)showMenu:顯示菜單。
下面給出程序運行的部分界面:
(1) 程序首先計算庫存量與銷售額,而后顯示菜單,提示用戶輸入數(shù)字1~6以進行對應操作,運行界面如圖1所示。
(2)若用戶輸入的菜單選項不滿足要求(未在1~6范圍內(nèi)),則給出提示信息,提示用戶重新輸入,直到用戶輸入正確選項,運行界面如圖2所示。
(3) 當用戶輸入正確菜單選項時,則調(diào)用對應函數(shù),運行界面如圖3所示(執(zhí)行菜單項1與5后的界面)、圖4(執(zhí)行菜單項3后的界面)。
(4) 當用戶輸入6時,結(jié)束程序執(zhí)行,否則將一直提示用戶進行輸入。
1. 2. 問題的解決方案
根據(jù)問題的描述,為實現(xiàn)程序的功能,可按照下述過程完成程序(僅供參考,可自行設計實現(xiàn)過程及方法):
* (1) 在主函數(shù)中定義結(jié)構體數(shù)組存儲五種商品的信息,并使用給出的數(shù)據(jù)對該數(shù)組進行初始化,而后調(diào)用cal函數(shù)進行計算。
* (2) 為方便用戶選擇,應提供良好的操作界面供用戶使用,根據(jù)不同的要求進入到對應的功能模塊。執(zhí)行完某個功能后,應重新顯示菜單,因此可定義顯示菜單函數(shù)showMenu,并將該函數(shù)的調(diào)用置于循環(huán)結(jié)構中。
* (3) 為實現(xiàn)根據(jù)用戶的不同輸入(共6個)調(diào)用對應函數(shù),應采用多分支結(jié)構,可使用switch語句或else if語句實現(xiàn)。為實現(xiàn)多次輸入,應將將菜單的顯示、用戶對菜單選項的輸入及各個功能模塊的調(diào)用置于一個循環(huán)結(jié)構,當輸入為6時,結(jié)束該循環(huán)。
* (4) 輸入待查找商品的代碼,再調(diào)用查找函數(shù)search進行查找,若找到,調(diào)用output函數(shù)輸出該商品的信息,否則輸出未找到的提示信息。
四、主要技術問題的描述
根據(jù)三的分析與描述,主要問題在于:
* 1. 結(jié)構體類型的構造(struct PRO)
為表示商品的完整信息,該類型應包括以下成員:代碼(int code)、名稱(char name[20]) ,總量(int amount) ,單價(double price),銷售量(int sale1),商品的庫存量(int stock),銷售額(double sale2)。
* 2. 函數(shù)的參數(shù)傳遞問題
由于該程序是對結(jié)構體數(shù)組的操作,因此使用傳遞地址的方法,并傳遞數(shù)組長度。以查找函數(shù)為例,該函數(shù)的原型說明語句為:int search(PRO s[],int n ,int x); ,即在長度為n的s數(shù)組中查找代碼為x的商品,若找到,則返回該商品的下標,否則返回-1。形參分別表示結(jié)構體數(shù)組,數(shù)組長度及待查商品的代碼。
* 3. 查詢后如何調(diào)用output函數(shù)只輸出一種商品的信息
已知output函數(shù)的原型說明語句為: void output(PRO s[],int n); ,因此若要輸出下標為k的一個商品的信息, 調(diào)用形式應為:output(s+k, 1); ,其中,s為結(jié)構體數(shù)組名,k為調(diào)用查詢函數(shù)search后返回的商品下標,1表示輸出商品的個數(shù)。
程序源代碼
#include <iostream> using namespace std; void showMenu() { cout<<"***************************"<<endl; cout<<"請輸入1~6內(nèi)的數(shù)字"<<endl; cout<<"1 按照庫存量升序排序\n"; cout<<"2 按照商品名稱降序排序\n"; cout<<"3 查找指定代碼的商品信息\n"; cout<<"4 計算銷售總額\n"; cout<<"5 輸出商品的信息\n"; cout<<"6 結(jié)束\n"; cout<<"***************************"<<endl; } struct PRO { int code;//代碼 char name[20];//名稱 int amount;//總量 double price;//單價 int sale1;//銷售量 int stock;//商品庫存量 double sale2;//銷售額 }; void cal(struct PRO s[],int n)//計算函數(shù) { for(int i=0;i<n;i++) { s[i].stock=s[i].amount-s[i].sale1; s[i].sale2=s[i].sale1*s[i].price; } } void sort1(struct PRO s[],int n)//按庫存量升序(小到大)排序,若庫存量相同則按銷售量升序排序,要求使用冒泡法排序。 { for(int i=0;i<n-1;i++)//比較n-1輪 { for(int j=0;j<n-i-1;j++)//每輪比較n-1-i次 { if(s[j].stock>s[j+1].stock||(s[j].stock==s[j+1].stock&&s[j].sale1>s[j+1].sale1)) { PRO a; a=s[j]; s[j]=s[j+1]; s[j+1]=a; } } } } void sort2(struct PRO s[],int n)//按商品名稱降序排序,要求使用選擇法排序。 { for(int i=0;i<n;i++) { int max=i; for(int j=i+1;j<n;j++) { if(strcmp(s[j].name, s[max].name)>0)max=j; } PRO temp; temp=s[i]; s[i]=s[max]; s[max]=temp; } } double total(PRO s[],int n)//計算并返回銷售總額(所有商品的銷售額的和)。 { double sum=0; for(int i=0;i<n;i++) { sum+=s[i].sale2; } return sum; } int search(PRO s[],int n,int x) { for(int i=0;i<n;i++) { if(x==s[i].code) { return i; } } return -1; } void output(struct PRO s[],int n) { cout<<"代碼 名稱 單價 總量 銷售量 庫存量 銷售額\n"; for(int i=0;i<n;i++) { printf("%5d\t%s\t%5.0f\t%5d\t%5d\t%5d\t%10.0f\n",s[i].code,s[i].name,s[i].price,s[i].amount,s[i].sale1,s[i].stock,s[i].sale2); } } int main(int argc, const char * argv[]) { int C; struct PRO s[5]= //商品信息初始化 { {10120,"HaierCon",155,2998,55,0,0}, {10564,"IPod MP3",245,1250,32,0,0}, {11254,"SegaHDisk",120,655,20,0,0}, {15826,"IBMLaptop",80,8188,15,0,0}, {18257,"SonyDigtC",150,3588,29,0,0} }; showMenu(); cal(s, 5); while(cin>>C) { if(C<1|C>6){cout<<"輸入錯誤,請輸入1~6范圍內(nèi)的數(shù)字"<<endl;continue;} else { switch (C) { case 1: { cout<<"按庫存量升序排序,請等待....\n"; sort1(s, 5); cout<<"排序結(jié)束.\n"; break; } case 2: { cout<<"按商品名稱降序排序,請等待....\n"; sort2(s, 5); cout<<"排序結(jié)束.\n"; break; } case 3: { int x; cout<<"請輸入指定商品的代碼:\n"; cin>>x; if(search(s,5,x)==-1) { cout<<"未找到,沒有該種商品!"<<endl; } else { cout<<"找到改商品,其信息為:"<<endl; output(s+search(s,5,x),1); } break; } case 4: cout<<"銷售總額為:"<<total(s, 5)<<endl; break; case 5: output(s, 5); break; case 6: exit(0); break; } } showMenu(); } return 0; }
感謝各位的閱讀!關于“使用C++實現(xiàn)商品管理程序的案例”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站bm7419.com,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
新聞標題:使用C++實現(xiàn)商品管理程序的案例-創(chuàng)新互聯(lián)
文章分享:http://bm7419.com/article34/ddpsse.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供響應式網(wǎng)站、企業(yè)建站、品牌網(wǎng)站制作、搜索引擎優(yōu)化、電子商務、標簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容