c語言課程設(shè)計(jì)銷售管理系統(tǒng)報(bào)告_第1頁
已閱讀1頁,還剩10頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、<p>  《高級(jí)語言程序設(shè)計(jì)》課程設(shè)計(jì)說明書</p><p>  設(shè)計(jì)題目:銷售管理系統(tǒng)設(shè)計(jì)</p><p><b>  1、題目與要求:</b></p><p><b>  1.1</b></p><p>  某公司有四個(gè)銷售員(編號(hào):1-4),負(fù)責(zé)銷售五種產(chǎn)品(編號(hào):1-5)。每個(gè)銷

2、售員都將當(dāng)日出售的每種產(chǎn)品各寫一張便條交上來。每張便條內(nèi)容有</p><p><b>  銷售員的代號(hào)</b></p><p><b>  產(chǎn)品的代號(hào)</b></p><p>  這種產(chǎn)品當(dāng)天的銷售額</p><p><b>  1.2</b></p><p

3、>  每位銷售員每天可能上繳0-5張便條。假設(shè)手機(jī)到了上個(gè)月的所有便條,編寫一個(gè)處理系統(tǒng),讀取上月的銷售情況(自己設(shè)定),進(jìn)行如下處理:</p><p>  計(jì)算上個(gè)月沒人每種產(chǎn)品的銷售額</p><p>  按銷售額對(duì)銷售員進(jìn)行排序,輸出排序結(jié)果(銷售員代號(hào))</p><p>  統(tǒng)計(jì)每種產(chǎn)品的總銷售額,對(duì)這些產(chǎn)品從高到低的順序輸出結(jié)果(須輸出產(chǎn)品的代號(hào)和銷

4、售額)</p><p><b>  輸出統(tǒng)計(jì)報(bào)表</b></p><p><b>  2、需求分析</b></p><p>  本程序?qū)⒂玫轿募到y(tǒng),list.txt文件內(nèi)容作為數(shù)據(jù)源,其中單行內(nèi)容代表一張紙條。程序運(yùn)行后首先將文件系統(tǒng)的原始數(shù)據(jù)讀取并保存到程序的結(jié)構(gòu)體數(shù)組當(dāng)中,所以應(yīng)提供文件輸入的操作;由于紙條數(shù)據(jù)零散,

5、所以要對(duì)原始數(shù)據(jù)進(jìn)行分類操作并提供一個(gè)數(shù)組用于保存分類信息;在程序中要進(jìn)行統(tǒng)計(jì)工作,所以要提供顯示、排序等操作;另外應(yīng)提供鍵盤式選擇菜單實(shí)現(xiàn)功能選擇。</p><p><b>  3、功能實(shí)現(xiàn)設(shè)計(jì)</b></p><p><b>  3.1總體設(shè)計(jì)</b></p><p>  根據(jù)上面的分析,可以將這個(gè)系統(tǒng)分為如下五大模塊

6、:查看每人每種產(chǎn)品的銷售額 、按銷售額對(duì)銷售員排序、對(duì)每種產(chǎn)品總銷售額從高到低排序、輸出統(tǒng)計(jì)報(bào)表和退出。其中主要模塊是前四個(gè)模塊。</p><p><b>  3.1流程圖</b></p><p><b>  4.源程序</b></p><p>  #include<stdio.h></p>&l

7、t;p>  #include<conio.h></p><p>  #include<stdlib.h></p><p>  #include<string.h></p><p>  #define M 155</p><p>  void detail();</p><p>

8、  void foreach();</p><p>  void menu();</p><p>  void product();</p><p>  void readdata();</p><p>  void seller();</p><p>  void total();</p><p&

9、gt;  void choice();</p><p><b>  struct ss</b></p><p><b>  {</b></p><p>  int sid; //銷售員代號(hào)</p><p>  int pid; //產(chǎn)品代號(hào)</p><p>  int s

10、n; //銷售額 </p><p><b>  }ss[M];</b></p><p>  int n; //紙條數(shù)目</p><p>  int s[4][5]={{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0}}; //用于保存員工和產(chǎn)品信息</p><p

11、>  void main() //入口函數(shù),即主函數(shù)</p><p><b>  {</b></p><p>  readdata(); //讀取文件數(shù)據(jù)</p><p>  foreach(); //根據(jù)文件初始數(shù)據(jù)初始化便于操作的數(shù)組</p><p>  menu(); //顯示主菜單<

12、/p><p><b>  }</b></p><p>  void readdata() //從文件讀取數(shù)據(jù)</p><p><b>  {</b></p><p><b>  FILE *fp;</b></p><p>  if((f

13、p=fopen("list.txt","r"))==NULL)</p><p><b>  {</b></p><p>  printf("Can't open the file!\n");</p><p><b>  exit(0);</b></p

14、><p><b>  }</b></p><p><b>  else </b></p><p>  for(n=0;!feof(fp);n++)</p><p><b>  {</b></p><p>  fscanf(fp,"%d %d %d\

15、n",&ss[n].sid,&ss[n].pid,&ss[n].sn);</p><p>  } //保存文件數(shù)據(jù)到結(jié)構(gòu)體</p><p>  fclose(fp);</p><p><b>  }</b></p><p>  void foreach() //從

16、紙條讀取數(shù)據(jù)并分類整理</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  for(i=0;i<n;i++) //遍歷所有紙條</p><p><b>  {</b></p><p&

17、gt;  switch(ss[i].pid) </p><p>  //按產(chǎn)品分大類,根據(jù)大類分銷售員小類,累加個(gè)人各產(chǎn)品銷售數(shù)量</p><p><b>  {</b></p><p><b>  case 1:</b></p><p>  switch(ss[i].sid)</p&

18、gt;<p><b>  {</b></p><p>  case 1:s[0][0]+=ss[i].sn;break;</p><p>  case 2:s[1][0]+=ss[i].sn;break;</p><p>  case 3:s[2][0]+=ss[i].sn;break;</p><p> 

19、 case 4:s[3][0]+=ss[i].sn;break;</p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  case 2:</b></p><p>  switch(ss[i].sid)</p&g

20、t;<p><b>  {</b></p><p>  case 1:s[0][1]+=ss[i].sn;break;</p><p>  case 2:s[1][1]+=ss[i].sn;break;</p><p>  case 3:s[2][1]+=ss[i].sn;break;</p><p>  

21、case 4:s[3][1]+=ss[i].sn;break;</p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  case 3:</b></p><p>  switch(ss[i].sid)</p>

22、;<p><b>  {</b></p><p>  case 1:s[0][2]+=ss[i].sn;break;</p><p>  case 2:s[1][2]+=ss[i].sn;break;</p><p>  case 3:s[2][2]+=ss[i].sn;break;</p><p>  c

23、ase 4:s[3][2]+=ss[i].sn;break;</p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  case 4:</b></p><p>  switch(ss[i].sid)</p>

24、<p><b>  {</b></p><p>  case 1:s[0][3]+=ss[i].sn;break;</p><p>  case 2:s[1][3]+=ss[i].sn;break;</p><p>  case 3:s[2][3]+=ss[i].sn;break;</p><p>  ca

25、se 4:s[3][3]+=ss[i].sn;break;</p><p><b>  }</b></p><p><b>  break;</b></p><p><b>  case 5:</b></p><p>  switch(ss[i].sid)</p>

26、<p><b>  {</b></p><p>  case 1:s[0][4]+=ss[i].sn;break;</p><p>  case 2:s[1][4]+=ss[i].sn;break;</p><p>  case 3:s[2][4]+=ss[i].sn;break;</p><p>  cas

27、e 4:s[3][4]+=ss[i].sn;break;</p><p><b>  };</b></p><p><b>  break; </b></p><p><b>  }</b></p><p><b>  }</b></p>

28、<p><b>  }</b></p><p>  void menu()</p><p><b>  {</b></p><p><b>  int w,c;</b></p><p><b>  do{</b></p><

29、p>  puts("\t\t********************菜單*********************\n\n");</p><p>  puts("\t\t 1.查看每人每種產(chǎn)品的銷售額\n");</p><p>  puts("\t\t 2.按銷售額對(duì)銷售員排序(銷售員代號(hào))\n");</p>

30、<p>  puts("\t\t 3.對(duì)每種產(chǎn)品總銷售額從高到低排序(產(chǎn)品代號(hào)和銷售額)\n");</p><p>  puts("\t\t 4.輸出統(tǒng)計(jì)報(bào)表\n");</p><p>  puts("\t\t 5.退出\n");</p><p>  puts("\n\n\t\t****

31、*****************************************\n");</p><p>  printf("請(qǐng)選擇(1-5):[ ]\b\b");</p><p>  scanf("%d",&c);</p><p>  if(c<1||c>5) //錯(cuò)誤輸入則重新獲取輸入

32、</p><p><b>  {</b></p><p><b>  w=1;</b></p><p>  getchar();</p><p><b>  }</b></p><p><b>  else w=0;</b><

33、/p><p>  } while(w==1);</p><p>  switch(c) //根據(jù)輸入實(shí)現(xiàn)相應(yīng)函數(shù)調(diào)用</p><p><b>  {</b></p><p><b>  case 1:</b></p><p>  detail();break;//每個(gè)

34、銷售員每種產(chǎn)品的銷售額統(tǒng)計(jì)</p><p><b>  case 2:</b></p><p>  seller();break;</p><p><b>  case 3:</b></p><p>  product();break;</p><p><b>  

35、case 4:</b></p><p>  total();break;</p><p><b>  case 5:</b></p><p><b>  exit(0);</b></p><p><b>  }</b></p><p><

36、;b>  }</b></p><p>  void detail() //顯示銷售情況</p><p><b>  {</b></p><p><b>  int i,j;</b></p><p>  for(i=0;i<4;i++)

37、 //遍歷銷售員</p><p><b>  {</b></p><p>  printf("\n\t\t%d號(hào)銷售員銷售情況:\n",i+1);</p><p>  for(j=0;j<5;j++) </p><p>  //

38、按銷售員分類遍歷所有產(chǎn)品并顯示信息</p><p>  printf("\t\t%d號(hào)產(chǎn)品銷售數(shù)量:%d\n",j+1,s[i][j]);</p><p><b>  }</b></p><p><b>  choice();</b></p><p><b>  }&l

39、t;/b></p><p>  void seller()</p><p><b>  {</b></p><p>  int i,j,k;</p><p>  int sp[4]={0,0,0,0};</p><p>  for(i=0;i<4;i++)</p><

40、;p>  for(j=0;j<5;j++)</p><p>  sp[i]+=s[i][j]; </p><p>  //計(jì)算每單個(gè)銷售員所有產(chǎn)品銷售數(shù)量</p><p>  for(i=0;i<4;i++) //比較四次,每次選出最大數(shù)</p><p>  { k=0;

41、 //用于標(biāo)記單輪最大數(shù)</p><p>  for(j=0;j<4;j++)</p><p>  if(sp[k]<sp[j])k=j; //獲取最大數(shù)標(biāo)號(hào)</p><p>  printf("\t\t第%d名是%d號(hào)銷售員!\n",i+1,k+1);sp[k]=-1; </p><p>  /

42、/輸出最大數(shù)和排名,將最大數(shù)標(biāo)記為負(fù)</p><p><b>  }</b></p><p>  choice();}</p><p>  void product() //與seller()原理一樣,用于對(duì)產(chǎn)品進(jìn)行統(tǒng)計(jì)</p><p>  { int i,j,k;</p><p&g

43、t;  int p[5]={0,0,0,0,0};</p><p>  for(j=0;j<5;j++)</p><p>  for(i=0;i<4;i++)</p><p>  p[j]+=s[i][j];</p><p>  for(j=0;j<5;j++)</p><p><b>  

44、{k=0;</b></p><p>  for(i=0;i<5;i++)</p><p>  if(p[k]<p[i])k=i;</p><p>  printf("\t\t第%d名是%d號(hào)產(chǎn)品!\t銷量為%d!\n",j+1,k+1,p[k]);p[k]=-1;}</p><p><b>

45、;  choice();</b></p><p><b>  }</b></p><p>  void total() //輸出報(bào)表</p><p>  { int i,j;</p><p>  printf("\n\t銷售員\t產(chǎn)品\t銷量\n");</p>&l

46、t;p>  for(i=0;i<4;i++)</p><p>  for(j=0;j<5;j++)</p><p>  printf("\t %d\t %d\t %d\n",i+1,j+1,s[i][j]);</p><p><b>  choice();</b></p><p>

47、<b>  }</b></p><p>  void choice() //用于輸出信息功能選擇</p><p><b>  {</b></p><p><b>  int c;</b></p><p>  printf("請(qǐng)選擇接下來想做什么\t1>

48、返回菜單\t2>退出系統(tǒng) [ ]\b\b");</p><p>  scanf("%d",&c);</p><p><b>  if(c==1)</b></p><p><b>  menu();</b></p><p><b>  els

49、e</b></p><p><b>  exit(0);</b></p><p>  puts('\n');</p><p><b>  }</b></p><p><b>  5.運(yùn)行結(jié)果</b></p><p><b

50、>  顯示主菜單:</b></p><p>  查看每人每種產(chǎn)品的銷售額運(yùn)行結(jié)果:</p><p>  按銷售額對(duì)銷售員排序運(yùn)行結(jié)果:</p><p>  對(duì)每種產(chǎn)品銷售額從高到低排序運(yùn)行結(jié)果:</p><p><b>  統(tǒng)計(jì)報(bào)表運(yùn)行結(jié)果:</b></p><p><b&

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論