已閱讀5頁,還剩11頁未讀, 繼續(xù)免費閱讀
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
精品文檔電子科技大學成都學院程序綜合設計銷售管理系統(tǒng)設計學生姓名馮垚學 號1240840106同 組 人 武俠紅 苗迅專業(yè)名稱機械設計制造及其自動化班 級12408401指導教師陳芳電子科技大學成都學院二一三年十二月目 錄1前言32設計目的33功能描述34總體設計41、功能模塊設計42、數(shù)據結構設計53、函數(shù)功能描述65程序實現(xiàn)81、源程序(略)82、運行結果136小結16.1前言C語言是今年來國內外得到迅速推廣使用的一種高級語言。C語言功能豐富,表達能力強,使用靈活方便,應用廣,目標程序效率高,可移植性好,既具有高級語言的優(yōu)點,又具有低級語言的語言特點,因此C語言對我們來說很重要,本程序是我們小組利用網絡和書本等資源公共完成的一個銷售管理系統(tǒng),深刻了解中小型C語言程序設計。2 設計目的(1) 了解管理信息系統(tǒng)的開發(fā)流程,熟悉C語言的文件和結構數(shù)組的各種基本操作。(2) 掌握高級程序設計語言的知識。 (3) 實踐中逐步掌握程序設計的思想和方法,培養(yǎng)問題求解和語言的應用能力。(4) 本程序中涉及結構體、數(shù)組、文件等方面的知識。通過本程序的訓練,能對C語言 的文件操作有一個更深刻的了解。(5) 要提高與程序設計和軟件開發(fā)有關的各種綜合能力。 (6) 掌握利用數(shù)組存儲結構實現(xiàn)電話簿管理的原理,為進一步開發(fā)出高質量的信息管理系統(tǒng)打下堅實的基礎。3 功能描述程序 功能要求 : 某公司有四個銷售員(編號:1-4),負責銷售五種產品(編號:1-5)。每個銷售員都將當天出售的每種產品各寫一張便條交上來。每張便條包含內容:1)銷售員的代號,2)產品的代號,3)這種產品的當天的銷售額。每位銷售員每天上繳1張便條。試設計一個便條管理系統(tǒng),使之能提供以下功能:1、系統(tǒng)以菜單方式工作2、便條信息錄入功能(便條信息用文件保存)輸入3、收集到了上個月的所有便條后,讀取銷售情況1)計算每個人每種產品的銷售額。2)按銷售額對銷售員進行排序,輸出排序結果(銷售員代號)3)統(tǒng)計每種產品的總銷售額,對這些產品按從高到底的順序,輸出排序結果(需輸出產品的代號和銷售額)(可選項)描述:本程序將用到list.txt文件內容作為數(shù)據源,其中單行內容代表一張紙條。程序運行后首先將文件系統(tǒng)的原始數(shù)據讀取并保存到程序的結構體數(shù)組當中,所以應提供文件輸入的操作;由于紙條數(shù)據零散,所以要對原始數(shù)據進行分類操作并提供一個數(shù)組用于保存分類信息;在程序中要進行統(tǒng)計工作,所以要提供顯示、排序等操作;另外應提供鍵盤式選擇菜單實現(xiàn)功能選擇。4 總體設計功能模塊設計開始可以將這個系統(tǒng)分為五大模塊:查看沒人每種產品的銷售額、按銷售額對銷售員排序、對每種產品總銷售額從高到低排序、輸出統(tǒng)計報表和退出。其中主要模塊是前四個模塊。程序預想流程在下圖。判斷文件是否能打開退出系統(tǒng)讀取便條上的信息主菜單沒人每種產品的銷售額銷售員銷售業(yè)績排序統(tǒng)計總銷售額并排序輸出統(tǒng)計報表選擇退出系統(tǒng)返回主菜單數(shù)據結構設計:頭文件和預定義#include#include#include#include#define M 155功能函數(shù)聲明:void detail();/顯示銷售情況 void foreach();/從文件讀取數(shù)據兵分類整理 void menu();/菜單 void product();/對產品進行統(tǒng)計 void readdata();/從文件讀取數(shù)據 void seller();/對銷售員進行統(tǒng)計 void total(); /輸出報表 void choice();/選擇輸出信息 數(shù)據結構:原始數(shù)據有銷售員代碼、產品代號和銷售額,所以定義一個全局結構體數(shù)組scrip用于保存原始數(shù)據。然后定義。然后定義全局變量n保存紙條數(shù)目,定義數(shù)組s用于保存分類后的信息。struct ss int sid; /銷售員代號int pid; /產品代號int sn; /銷售額 ssM; int n; /紙條數(shù)目int s45=0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0; /用于保存員工和產品信息主函數(shù):顯示程序設計者相關信息和調用文件讀取函數(shù)、數(shù)據初始化函數(shù)和主菜單函數(shù)。void main() /入口函數(shù)即主函數(shù) readdata(); /讀取文件數(shù)據 foreach(); /根據文件初始數(shù)據初始化便于操作的數(shù)組 menu(); /顯示主菜單 函數(shù)功能描述:每人每種產品銷售額統(tǒng)計函數(shù)detail()/計算上個月每個人每種產品的銷售額void detail() /顯示銷售情況int i,j;for(i=0;i4;i+) /遍歷銷售員 printf(ntt%d號銷售員銷售情況:n,i+1);for(j=0;j5;j+) /*按銷售員分類遍歷所有產品并顯示信息*/printf(tt%d號產品銷售數(shù)量:%dn,j+1,sij);choice();文件讀取函數(shù)readdata()讀出便條中的內容,并保存到文件結構體中。void foreach()/從紙條讀取數(shù)據并分類整理int i;for(i=0;in;i+)/遍歷所有紙條switch(ssi.pid)/按產品分大類,根據大類分銷售員小類,累加個人各產品銷售數(shù)量case 1:switch(ssi.sid)case 1:s00+=ssi.sn;break; case 2:s10+=ssi.sn;break;case 3:s20+=ssi.sn;break;case 4:s30+=ssi.sn;break;break;case 2:switch(ssi.sid)case 1:s01+=ssi.sn;break;case 2:s11+=ssi.sn;break;case 3:s21+=ssi.sn;break;case 4:s31+=ssi.sn;break;break;case 3:switch(ssi.sid)case 1:s02+=ssi.sn;break;case 2:s12+=ssi.sn;break;case 3:s22+=ssi.sn;break;case 4:s32+=ssi.sn;break;break;case 4:switch(ssi.sid)case 1:s03+=ssi.sn;break;case 2:s13+=ssi.sn;break;case 3:s23+=ssi.sn;break;case 4:s33+=ssi.sn;break;break;case 5:switch(ssi.sid)case 1:s04+=ssi.sn;break;case 2:s14+=ssi.sn;break;case 3:s24+=ssi.sn;break;case 4:s34+=ssi.sn;break;break;主菜單函數(shù)menu()顯示系統(tǒng)功能菜單以供用戶選擇相關功能使用,根據用戶選擇分別可調用。void menu()int w,c;doputs(tt*菜單*nn);puts(tt 1.查看每人每種產品的銷售額n);puts(tt 2.按銷售額對銷售員排序(銷售員代號)n);puts(tt 3.對每種產品總銷售額從高到低排序(產品代號和銷售額)n);puts(tt 4.輸出統(tǒng)計報表n);puts(tt 5.退出n);puts(nntt*n);printf(請選擇(1-5): bb);scanf(%d,&c);if(c5) /錯誤輸入則重新獲取輸如w=1;getchar();else w=0;while(w=1);switch(c)/根據輸入實現(xiàn)相應函數(shù)調用case 1:detail();break;/每個銷售員每種產品的銷售額統(tǒng)j計case 2:seller();break;case 3:product();break;case 4:total();break;case 5:exit(0);統(tǒng)計報表輸出函數(shù)total()統(tǒng)計每種產品的總銷售額,對這些產品按從高到低的順序輸出排序結果(需輸出產品代號和銷售額)void total()/輸出報表int i,j;printf(nt銷售員t產品t銷量n);for(i=0;i4;i+)for(j=0;j5;j+)printf(t %dt %dt %dn,i+1,j+1,sij);choice();5程序實現(xiàn)1、源程序#include #include #include #include #define M 155 void detail();/顯示銷售情況 void foreach();/從文件讀取數(shù)據兵分類整理 void menu();/菜單 void product();/對產品進行統(tǒng)計 void readdata();/從文件讀取數(shù)據 void total(); /輸出報表 void choice();/選擇輸出信息 struct ss int sid; /銷售員代號int pid; /產品代號int sn; /銷售額 ssM; int n; /紙條數(shù)目 int s45=0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0; /用于保存員工和產品信息void main() /入口函數(shù)即主函數(shù) readdata(); /讀取文件數(shù)據 foreach(); /根據文件初始數(shù)據初始化便于操作的數(shù)組 menu(); /顯示主菜單 void readdata()/從文件讀取數(shù)據 FILE *fp; if(fp=fopen(list.txt,r)=NULL) printf(Cant open the file!n); exit(0);else for(n=0;!feof(fp);n+) fscanf(fp,%d %d %dn,&ssn.sid,&ssn.pid,&ssn.sn); /保存文件數(shù)據到結構體fclose(fp);void foreach()/從紙條讀取數(shù)據并分類整理int i;for(i=0;in;i+)/遍歷所有紙條switch(ssi.pid)/按產品分大類,根據大類分銷售員小類,累加個人各產品銷售數(shù)量case 1:switch(ssi.sid)case 1:s00+=ssi.sn;break; case 2:s10+=ssi.sn;break;case 3:s20+=ssi.sn;break;case 4:s30+=ssi.sn;break;break;case 2:switch(ssi.sid)case 1:s01+=ssi.sn;break;case 2:s11+=ssi.sn;break;case 3:s21+=ssi.sn;break;case 4:s31+=ssi.sn;break;break;case 3:switch(ssi.sid)case 1:s02+=ssi.sn;break;case 2:s12+=ssi.sn;break;case 3:s22+=ssi.sn;break;case 4:s32+=ssi.sn;break;break;case 4:switch(ssi.sid)case 1:s03+=ssi.sn;break;case 2:s13+=ssi.sn;break;case 3:s23+=ssi.sn;break;case 4:s33+=ssi.sn;break;break;case 5:switch(ssi.sid)case 1:s04+=ssi.sn;break;case 2:s14+=ssi.sn;break;case 3:s24+=ssi.sn;break;case 4:s34+=ssi.sn;break;break;void menu()int w,c;doputs(tt*菜單*nn);puts(tt 1.查看每人每種產品的銷售額n);puts(tt 2.按銷售額對銷售員排序(銷售員代號)n);puts(tt 3.對每種產品總銷售額從高到低排序(產品代號和銷售額)n);puts(tt 4.輸出統(tǒng)計報表n);puts(tt 5.退出n);puts(nntt*n);printf(請選擇(1-5): bb);scanf(%d,&c);if(c5) /錯誤輸入則重新獲取輸如w=1;getchar();else w=0;while(w=1);switch(c)/根據輸入實現(xiàn)相應函數(shù)調用case 1:detail();break;/每個銷售員每種產品的銷售額統(tǒng)j計case 2:seller();break;case 3:product();break;case 4:total();break;case 5:exit(0);void detail()/顯示銷售情況int i,j;for(i=0;i4;i+)/遍歷銷售員printf(ntt%d號銷售員銷售情況:n,i+1);for(j=0;j5;j+)/*按銷售員分類遍歷所有產品并顯示信息*/printf(tt%d號產品銷售數(shù)量:%dn,j+1,sij);choice();void seller()int i,j,k;int sp4=0,0,0,0;for(i=0;i4;i+)for(j=0;j5;j+)spi+=sij;/計算每單個銷售員所有產品銷售情況for(i=0;i4;i+)/比較四次,每次選出最大數(shù)k=0;/用于標記單輪最大數(shù)for(j=0;j4;j+)if(spkspj)k=j;/獲取最大數(shù)標號printf(tt第%d名是%d號銷售員!n,i+1,k+1);spk=-1;/*輸出最大數(shù)和排名,將最大數(shù)標記為負*/choice();void product()/與seller()原理一樣,用于對產品進行統(tǒng)計int i,j,k;int p5=0,0,0,0,0;for(j=0;j5;j+)for(i=0;i4;i+)pj+=sij;for(j=0;j5;j+)k=0;for(i=0;i5;i+)if(pkpi)k=i;printf(tt第%d名是%d號產品!t銷量為%d!n,j+1,k+1,pk);pk=-1;choice();void total()/輸出報表int i,j;printf(nt銷售員t產品t銷量n);for(i=0;i4;i+)for(j=0;j返回菜單t2退出系統(tǒng) bb); scanf(%d,&c);if(c=1)menu();elseexit(0);puts(n); 2、運行結果(1)主界面 (2
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年影視合作:紀錄片拍攝協(xié)議樣本3篇
- 二零二五年度酒店客房家具定制合作協(xié)議3篇
- 2025年度股權激勵計劃合同(含績效考核)3篇
- 二零二五年防火門安裝與消防系統(tǒng)改造服務合同3篇
- 二零二五年酒店安保人員勞動合同細則3篇
- 二零二五版商業(yè)停車場車位租賃與維護服務合同3篇
- 2025年度網絡營銷合同詳細描述營銷標的及策略2篇
- 閔行區(qū)工廠搬遷施工方案
- 二零二五年度股權交易增資補充協(xié)議書3篇
- 2023-2029年中國包車服務轎車行業(yè)市場發(fā)展現(xiàn)狀及投資戰(zhàn)略咨詢報告
- 資金審批權限管理規(guī)定
- 《工業(yè)園區(qū)節(jié)水管理技術規(guī)范(征求意見稿)》編制說明
- GB/T 44186-2024固定式壓縮空氣泡沫滅火系統(tǒng)
- 血液凈化十大安全目標
- 福建省漳州市2024年高一下數(shù)學期末調研模擬試題含解析
- 中國保險行業(yè)協(xié)會官方-2023年度商業(yè)健康保險經營數(shù)據分析報告-2024年3月
- 家具桌子設計說明
- DB32T3622-2019水利地理信息圖形標示
- 2024年代理記賬工作總結6篇
- 4D廚房管理對比
- 2024年大型集團公司IT信息化頂層規(guī)劃報告
評論
0/150
提交評論