c語(yǔ)言課程設(shè)計(jì)論文--銷售管理系統(tǒng)_第1頁(yè)
已閱讀1頁(yè),還剩28頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡(jiǎn)介

1、<p><b>  C語(yǔ)言課程設(shè)計(jì)論文</b></p><p>  學(xué) 院: 計(jì)算機(jī)學(xué)院 </p><p>  題 目: 銷售管理系統(tǒng) </p><p><b>  銷售管理系統(tǒng)</b></p><p><b>  摘 要&l

2、t;/b></p><p>  在銷售管理當(dāng)中,人工統(tǒng)計(jì)的速度慢,且容易出現(xiàn)差錯(cuò)。本銷售管理系統(tǒng)的自動(dòng)化加速了統(tǒng)計(jì)工作,提高管理效率。本程序主要采用對(duì)零散的紙條進(jìn)行自動(dòng)讀取,然后按組分類將數(shù)據(jù)保存到數(shù)組,這樣的結(jié)構(gòu)化非常便于程序后續(xù)的統(tǒng)計(jì)工作。統(tǒng)計(jì)具體過(guò)程涉及到個(gè)人銷量排序與產(chǎn)品銷量排序等問(wèn)題,將于正文中詳細(xì)介紹。本程序?qū)崿F(xiàn)了所有設(shè)計(jì)要求。</p><p>  關(guān)鍵詞:文件,排序,統(tǒng)

3、計(jì)</p><p><b>  目 錄 </b></p><p><b>  中文摘要Ⅰ</b></p><p><b>  1 題目要求1</b></p><p>  1.1 要求.1</p><p><b>  2 需求分析

4、1</b></p><p><b>  3 總體設(shè)計(jì)1</b></p><p><b>  詳細(xì)設(shè)計(jì)2</b></p><p><b>  4.1主函數(shù)2</b></p><p>  4.2各功能模塊設(shè)計(jì)5</p><p>  4

5、.3 公共函數(shù)6</p><p>  5.運(yùn)行結(jié)果(附帶抓圖)7</p><p><b>  6.總結(jié)10</b></p><p>  附錄A 練習(xí)題源碼11</p><p><b>  參考文獻(xiàn)27</b></p><p><b>  1 題目要求&

6、lt;/b></p><p><b>  1.1 要求</b></p><p>  某公司有四個(gè)銷售員(編號(hào):1-4),負(fù)責(zé)銷售五種產(chǎn)品(編號(hào):1-5)。每個(gè)銷售員都將當(dāng)日出售的每種產(chǎn)品各寫一張便條交上來(lái)。每張便條內(nèi)容包含:</p><p><b>  銷售員的代號(hào)</b></p><p>

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

8、,輸出排序結(jié)果(銷售員代號(hào))</p><p>  統(tǒng)計(jì)每種產(chǎn)品的總銷售額,對(duì)這些產(chǎn)品從高到低的順序輸出結(jié)果(須輸出產(chǎn)品的代號(hào)和銷售額)</p><p><b>  輸出統(tǒng)計(jì)報(bào)表</b></p><p><b>  2 需求分析</b></p><p>  本程序?qū)⒂玫轿募到y(tǒng),list.txt文件

9、內(nèi)容作為數(shù)據(jù)源,其中單行內(nèi)容代表一張紙條。程序運(yùn)行后首先將文件系統(tǒng)的原始數(shù)據(jù)讀取并保存到程序的結(jié)構(gòu)體數(shù)組當(dāng)中,所以應(yīng)提供文件輸入的操作;由于紙條數(shù)據(jù)零散,所以要對(duì)原始數(shù)據(jù)進(jìn)行分類操作并提供一個(gè)數(shù)組用于保存分類信息;在程序中要進(jìn)行統(tǒng)計(jì)工作,所以要提供顯示、排序等操作;另外應(yīng)提供鍵盤式選擇菜單實(shí)現(xiàn)功能選擇。</p><p><b>  總體設(shè)計(jì)</b></p><p> 

10、 根據(jù)上面的分析,可以將這個(gè)系統(tǒng)分為如下五大模塊:查看每人每種產(chǎn)品的銷售額 、按銷售額對(duì)銷售員排序、對(duì)每種產(chǎn)品總銷售額從高到低排序、輸出統(tǒng)計(jì)報(bào)表和退出。其中主要模塊是前四個(gè)模塊。</p><p><b>  4 詳細(xì)設(shè)計(jì)</b></p><p><b>  主函數(shù)</b></p><p><b>  【數(shù)據(jù)結(jié)構(gòu)

11、】</b></p><p>  原始數(shù)據(jù)有員工代號(hào)、產(chǎn)品代號(hào)和銷售額,所以定義一個(gè)全局結(jié)構(gòu)體數(shù)組scrip用于保存原始數(shù)據(jù)。然后定義全局變量n保存紙條數(shù)目,定義數(shù)組s用于保存分類后的信息。</p><p><b>  【數(shù)據(jù)結(jié)構(gòu)代碼】</b></p><p>  struct scrip</p><p>&l

12、t;b>  {</b></p><p>  int sid; //銷售員代號(hào)</p><p>  int pid; //產(chǎn)品代號(hào)</p><p>  int sn; //銷售額 </p><p>  }scrip[M];</p><p>  int n; //紙條數(shù)目</

13、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>  注函數(shù)通過(guò)調(diào)用readdata()讀取文件數(shù)據(jù),然后使用foreach()函數(shù)初始化產(chǎn)生便于操作的保存數(shù)據(jù)的數(shù)組,初始化工作完成之后執(zhí)行menu()顯示主菜單。</p><p>&l

14、t;b>  【程序】</b></p><p>  void main() //入口函數(shù)</p><p><b>  {</b></p><p>  readdata(); //讀取文件數(shù)據(jù)</p><p>  foreach(); //根據(jù)文件初始數(shù)據(jù)初始化便于操作的數(shù)組</p>

15、<p>  menu(); //顯示主菜單</p><p><b>  }</b></p><p>  readdata()讀取文件數(shù)據(jù)</p><p>  readdata()函數(shù)從list.txt文件讀取數(shù)據(jù),將數(shù)據(jù)保存到程序的結(jié)構(gòu)體當(dāng)中。</p><p><b>  【程序】<

16、/b></p><p>  void readdata() //從文件讀取數(shù)據(jù)</p><p><b>  {</b></p><p><b>  FILE *fp;</b></p><p>  if((fp=fopen("list.txt",&quo

17、t;r"))==NULL)printf("Can't open the file!\n");</p><p>  else for(n=0;!feof(fp);n++){fscanf(fp,"%d %d %d\n",&scrip[n].pid,&scrip[n].sid,&scrip[n].sn);}; //保存文件數(shù)據(jù)到結(jié)構(gòu)體

18、</p><p>  fclose(fp);</p><p><b>  }</b></p><p>  4.1.2 foreach()根據(jù)文件初始數(shù)據(jù)初始化便于操作的數(shù)組</p><p>  foreach()從紙條讀取數(shù)據(jù)并按照銷售員和產(chǎn)品種類分類整理保存到一個(gè)二維數(shù)組,方便統(tǒng)計(jì)操作。</p><

19、;p><b>  【程序】</b></p><p>  void foreach() //從紙條讀取數(shù)據(jù)并分類整理</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  for(i=0;i&l

20、t;n;i++) //遍歷所有紙條</p><p><b>  {</b></p><p>  switch(scrip[i].pid) </p><p>  //按產(chǎn)品分大類,根據(jù)大類分銷售員小類,累加個(gè)人各產(chǎn)品銷售數(shù)量</p><p><b>  {</b></p>

21、;<p><b>  case 1:</b></p><p>  switch(scrip[i].sid)</p><p>  {case 1:s[0][0]+=scrip[i].sn;break;</p><p>  case 2:s[1][0]+=scrip[i].sn;break;</p><p> 

22、 case 3:s[2][0]+=scrip[i].sn;break;</p><p>  case 4:s[3][0]+=scrip[i].sn;break;}break;</p><p><b>  case 2:</b></p><p>  switch(scrip[i].sid)</p><p>  {case

23、1:s[0][1]+=scrip[i].sn;break;</p><p>  case 2:s[1][1]+=scrip[i].sn;break;</p><p>  case 3:s[2][1]+=scrip[i].sn;break;</p><p>  case 4:s[3][1]+=scrip[i].sn;break;}break;</p>&

24、lt;p><b>  case 3:</b></p><p>  switch(scrip[i].sid)</p><p>  {case 1:s[0][2]+=scrip[i].sn;break;</p><p>  case 2:s[1][2]+=scrip[i].sn;break;</p><p>  cas

25、e 3:s[2][2]+=scrip[i].sn;break;</p><p>  case 4:s[3][2]+=scrip[i].sn;break;}break;</p><p><b>  case 4:</b></p><p>  switch(scrip[i].sid)</p><p>  {case 1:s[

26、0][3]+=scrip[i].sn;break;</p><p>  case 2:s[1][3]+=scrip[i].sn;break;</p><p>  case 3:s[2][3]+=scrip[i].sn;break;</p><p>  case 4:s[3][3]+=scrip[i].sn;break;}break;</p><p

27、><b>  case 5:</b></p><p>  switch(scrip[i].sid)</p><p>  {case 1:s[0][4]+=scrip[i].sn;break;</p><p>  case 2:s[1][4]+=scrip[i].sn;break;</p><p>  case 3:

28、s[2][4]+=scrip[i].sn;break;</p><p>  case 4:s[3][4]+=scrip[i].sn;break;};break; </p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b

29、></p><p>  4.1.3 menu()顯示主菜單</p><p>  用于顯示菜單,獲取用戶選項(xiàng)進(jìn)入相應(yīng)模塊。</p><p><b>  【程序】</b></p><p>  void menu()</p><p><b>  {</b></p>

30、;<p><b>  int w,c;</b></p><p><b>  do{</b></p><p>  puts("\t\t********************MENU*********************\n\n");</p><p>  puts("\t\t

31、1.查看每人每種產(chǎn)品的銷售額\n");</p><p>  puts("\t\t 2.按銷售額對(duì)銷售員排序(銷售員代號(hào))\n");</p><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&qu

32、ot;);</p><p>  puts("\t\t 5.退出\n");</p><p>  puts("\n\n\t\t*********************************************\n");</p><p>  printf("Choice your number(1-5):[ ]\b

33、\b");</p><p>  scanf("%d",&c);</p><p>  if(c<1||c>5) //錯(cuò)誤輸入則重新獲取輸入</p><p><b>  {</b></p><p><b>  w=1;</b></p>

34、<p>  getchar();</p><p><b>  }</b></p><p><b>  else w=0;</b></p><p>  } while(w==1);</p><p>  switch(c) //根據(jù)輸入實(shí)現(xiàn)相應(yīng)函數(shù)調(diào)用</p><

35、;p><b>  {</b></p><p><b>  case 1:</b></p><p><b>  detail();</b></p><p><b>  break;</b></p><p><b>  case 2:</

36、b></p><p><b>  seller();</b></p><p><b>  break;</b></p><p><b>  case 3:</b></p><p>  product();</p><p><b>  br

37、eak;</b></p><p><b>  case 4:</b></p><p><b>  total();</b></p><p><b>  break;</b></p><p><b>  case 5:</b></p>

38、<p><b>  exit(0);</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  各功能模塊設(shè)計(jì)</b></p><p>  查看每人每種產(chǎn)品的銷售額模塊</p&g

39、t;<p>  由于在初始化當(dāng)中已經(jīng)進(jìn)行分類整理,所以現(xiàn)在只要通過(guò)遍歷s數(shù)組就可以將統(tǒng)計(jì)信息顯示出來(lái)。</p><p><b>  【程序】</b></p><p>  void detail() //顯示銷售情況</p><p><b>  {</b></p>

40、<p><b>  int i,j;</b></p><p>  void menu();</p><p>  for(i=0;i<4;i++) //遍歷銷售員</p><p><b>  {</b></p><p>  printf("\n\t\t%d號(hào)

41、銷售員銷售情況:\n",i+1);</p><p>  for(j=0;j<5;j++) </p><p>  //按銷售員分類遍歷所有產(chǎn)品并顯示信息</p><p>  printf("\t\t%d號(hào)產(chǎn)品銷售數(shù)量:%d\n",j+1,s[i][j]);</p>

42、;<p><b>  }</b></p><p><b>  wait();</b></p><p><b>  }</b></p><p>  按銷售額對(duì)銷售員排序</p><p>  計(jì)算每單個(gè)銷售員所有產(chǎn)品銷售數(shù)量,用一個(gè)FOR循環(huán)循環(huán)四次,每次獲取最大值后

43、輸出,輸出之后將最大值標(biāo)記為-1,然后進(jìn)行下次循環(huán),由此獲得由大到小的排行。</p><p><b>  【程序】</b></p><p>  void seller()</p><p><b>  {</b></p><p>  int i,j,k;</p><p>  i

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

45、;p>  { k=0; //用于標(biāo)記單輪最大數(shù)</p><p>  for(j=0;j<4;j++)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

46、>  //輸出最大數(shù)和排名,將最大數(shù)標(biāo)記為負(fù)</p><p><b>  }</b></p><p><b>  wait();</b></p><p><b>  }</b></p><p>  對(duì)每種產(chǎn)品總銷售額從高到低排序</p><p> 

47、 計(jì)算每單個(gè)產(chǎn)品銷售數(shù)量,用一個(gè)FOR循環(huán)循環(huán)五次,每次獲取最大值后輸出,輸出之后將最大值標(biāo)記為-1,然后進(jìn)行下次循環(huán),由此獲得由大到小的排行。</p><p><b>  【程序】</b></p><p>  void product() //與seller()原理一樣,用于對(duì)產(chǎn)品進(jìn)行統(tǒng)計(jì)</p><p><b> 

48、 { </b></p><p>  int i,j,k;</p><p>  void menu();</p><p>  int p[5]={0,0,0,0,0};</p><p>  for(j=0;j<5;j++)for(i=0;i<4;i++)p[j]+=s[i][j];</p><p&g

49、t;  for(j=0;j<5;j++)</p><p><b>  {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&quo

50、t;,j+1,k+1,p[k]);p[k]=-1;</p><p><b>  }</b></p><p><b>  wait();</b></p><p><b>  }</b></p><p><b>  輸出統(tǒng)計(jì)報(bào)表</b></p>

51、<p>  輸出報(bào)表,將數(shù)組中的統(tǒng)計(jì)信息輸出到屏幕。</p><p><b>  【程序】</b></p><p>  void total() //輸出報(bào)表</p><p><b>  {</b></p><p>  printf("\n\t銷售員\t產(chǎn)品\t銷量\n&q

52、uot;);</p><p>  for(int i=0;i<4;i++)for(int j=0;j<5;j++)printf("\t %d\t %d\t %d\n",i+1,j+1,s[i][j]);</p><p><b>  wait();</b></p><p><b>  }</b&g

53、t;</p><p><b>  退出</b></p><p>  exit()為系統(tǒng)函數(shù),退出程序時(shí)使用。</p><p><b>  4.3 公共函數(shù)</b></p><p>  wait()函數(shù)用于輸出信息后的等待,通過(guò)getchar()等待用戶輸入并提示相關(guān)信息,完成后調(diào)用菜單函數(shù)menu(

54、)。detail()顯示銷售情況的函數(shù),通過(guò)遍歷數(shù)組按銷售員分類遍歷所有產(chǎn)品并顯示信息。</p><p><b>  【程序】</b></p><p>  void wait() //用于輸出信息后的等待</p><p><b>  {</b></p><p>  void menu();

55、</p><p>  printf("\n\t\t按回車鍵返回主菜單...\n\n");</p><p>  getchar();</p><p><b>  menu();</b></p><p><b>  }</b></p><p>  5 運(yùn)行

56、結(jié)果(附帶抓圖)</p><p>  List.txt文件中數(shù)據(jù)如下:</p><p><b>  1 1 1</b></p><p><b>  2 2 2</b></p><p><b>  3 3 3</b></p><p><b>  

57、4 4 4</b></p><p><b>  程序運(yùn)行結(jié)果:</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)表

58、運(yùn)行結(jié)果:</b></p><p><b>  6 總結(jié)</b></p><p>  通過(guò)這次C程序設(shè)計(jì),我掌握了模塊化設(shè)計(jì)方法,能夠深入的理解結(jié)構(gòu)化程序設(shè)計(jì)思想,熟練運(yùn)用結(jié)構(gòu)化程序設(shè)計(jì)方法,提高了運(yùn)用C語(yǔ)言進(jìn)行程序設(shè)計(jì)的能力。</p><p>  附錄 A 練習(xí)題源碼</p><p><b>

59、;  Unit2</b></p><p>  #include <stdio.h></p><p>  #include <string.h></p><p>  #include <stdlib.h> </p><p>  #define N 50</p><p>  

60、#define M 50</p><p>  struct sporter</p><p>  {int num;</p><p>  char name[20];</p><p>  int vote_num;</p><p><b>  }spt[N];</b></p><

61、;p>  int score_order;</p><p>  int score_hit;</p><p>  int score_sum;</p><p><b>  int n,m;</b></p><p>  struct vote</p><p>  {char id[10];&

62、lt;/p><p>  char name[20];</p><p>  char address[20];</p><p>  int a[10];</p><p>  int score_order;</p><p>  int score_hit;</p><p>  int score_su

63、m;</p><p><b>  }vot[M];</b></p><p>  int load_sporter()</p><p>  {FILE *fp;</p><p><b>  int i;</b></p><p>  if((fp=fopen("spo

64、rter.txt","r"))==NULL)</p><p>  {printf("\nCannot open file!\n");</p><p>  return 0;}</p><p>  for(i=0;!feof(fp);i++)</p><p>  fscanf(fp,&q

65、uot;%d %s",&spt[i].num,&spt[i].name);</p><p>  fclose(fp);</p><p>  return i;}</p><p>  void printf_one(int i)</p><p>  {printf("%2d %-17s %d\n"

66、,spt[i].num,spt[i].name,spt[i].vote_num);}</p><p>  void printf_n(int n)</p><p><b>  {int j;</b></p><p>  for(j=0;j<n;j++)</p><p>  {if(j%10==0)</

67、p><p>  {printf("\n\nPress any key to contiune ...");</p><p>  getchar();</p><p>  puts("\n\n");}</p><p>  printf_one(j);}</p><p>  

68、getchar();}</p><p>  int load_vote()</p><p>  {FILE *fp;</p><p><b>  int i,j;</b></p><p>  if((fp=fopen("vote.txt","r"))==NULL)</p&g

69、t;<p>  {printf("\nConnot open file\n");</p><p>  return 0;}</p><p>  for(i=0;!feof(fp);i++)</p><p>  {fscanf(fp,"%s%s%s",&vot[i].id,&vot[i].

70、name,&vot[i].address);</p><p>  for(j=0;j<10;j++)</p><p>  fscanf(fp,"%d",&vot[i].a[j]);}</p><p>  fclose(fp);</p><p>  return i;}</p><

71、p>  void readfiles()</p><p>  {n=load_sporter();</p><p>  printf_n(n);</p><p>  m=load_vote();}</p><p>  void stat_vote(int m)</p><p>  {int i,j,k;<

72、;/p><p>  for(i=0;i<=m;i++)</p><p>  {for(j=0;j<10;j++)</p><p>  for(k=0;k<20;k++)</p><p>  if(vot[i].a[j]==spt[k].num)</p><p>  spt[k].vote_num++;

73、}</p><p><b>  }</b></p><p>  void order_by_vote(int n)</p><p>  {int i,j,k;</p><p>  struct sporter s;</p><p>  for(i=0;i<m-1;i++)</

74、p><p><b>  {</b></p><p><b>  k=i;</b></p><p>  for(j=i+1;j<m;j++)</p><p>  if(spt[i].vote_num>spt[k].vote_num)</p><p><b> 

75、 k=j;</b></p><p><b>  s=spt[i];</b></p><p>  spt[i]=spt[k];</p><p><b>  spt[k]=s;</b></p><p><b>  }}</b></p><p> 

76、 int save_spt()</p><p>  {FILE *fp1;</p><p><b>  int i;</b></p><p>  if((fp1=fopen("spt10.txt","w"))==NULL)</p><p>  {printf("\n

77、Cannot open file\n");</p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  for(i=0;i<10;i++)</p><p>  fprintf(fp1,"%d %s %d\n"

78、,spt[i].num,spt[i].name,spt[i].vote_num);</p><p>  fclose(fp1);</p><p><b>  return 1;</b></p><p><b>  }</b></p><p>  void print_spt10()</p>

79、;<p><b>  {int i;</b></p><p>  printf("\n\nThe 10 best sporter is:\n");</p><p>  printf("order,num,name,vote_num\n");</p><p>  for(i=0;i<1

80、0;i++)printf("%5d: %3d, %10s, %d \n",i+1,spt[i].num,spt[i].name,spt[i].vote_num);getchar();</p><p>  save_spt();}</p><p>  void calctensp()</p><p>  {stat_vote(m);</

81、p><p>  order_by_vote(n);</p><p>  print_spt10();}</p><p>  int calc_hit(int m)</p><p>  {FILE *fp;</p><p>  int i,j,k;</p><p>  struct sporter

82、s[10];</p><p>  for(i=0;i<10;i++)s[i]=spt[i];</p><p>  for(i=0;i<m;i++)for(j=0;j<10;j++)for(k=0;k<10;k++)</p><p>  {if(vot[i].a[j]==s[j].num)</p><p>  vot

83、[i].score_order+=9-j;</p><p>  if(vot[i].a[j]==s[k].num)</p><p>  vot[i].score_hit+=10;</p><p>  vot[i].score_sum=vot[i].score_hit+vot[i].score_order;}</p><p>  if((fp

84、=fopen("hit.txt","w"))==NULL)</p><p>  {printf("\nCannot open file\n");</p><p>  return 0;}</p><p>  for(i=0;i<m;i++)fprintf(fp,"%s %d %d %

85、d\n",vot[i].id,vot[i].score_order,vot[i].score_hit,vot[i].score_sum);</p><p>  fclose(fp);</p><p><b>  return 1;</b></p><p><b>  }</b></p><p&

86、gt;  void sort_vote(int m)</p><p>  {int i,j,k;</p><p>  struct vote v;</p><p>  for(i=0;i<m-1;i++)</p><p><b>  {k=i;</b></p><p>  for(j=

87、i+1;j<m;j++)</p><p>  if(vot[j].score_sum>vot[k].score_sum) k=j;</p><p>  v=vot[i];vot[i]=vot[k];vot[k]=v;}}</p><p>  void print_vot10()</p><p><b>  {int

88、i;</b></p><p>  printf("\n\nThe 10 best voter is:\n");</p><p>  printf("order,id,name,vote_sum\n");</p><p>  for(i=0;i<10;i++)</p><p>  {p

89、rintf("%5d:%s,%10s,%d\n",i+1,vot[i].id,vot[i].name,vot[i].score_sum);}</p><p>  getchar();</p><p><b>  }</b></p><p>  int save_vot10()</p><p>  {

90、FILE *fp1;</p><p><b>  int i;</b></p><p>  if((fp1=fopen("vot10.txt","w"))==NULL)</p><p>  {printf("\nCannot open file\n");</p>&

91、lt;p>  return 0;}</p><p>  for(i=0;i<10;i++)</p><p>  fprintf(fp1,"%5d: %s,%10s,%d\n",i+1,vot[i].id,vot[i].name,vot[i].score_sum);</p><p>  fclose(fp1);</p>

92、<p><b>  return 1;</b></p><p><b>  }</b></p><p>  void stattenvoter()</p><p>  {calc_hit(m);</p><p>  sort_vote(m);</p><p>  

93、print_vot10();</p><p>  save_vot10();</p><p><b>  }</b></p><p>  void stat()</p><p>  {readfiles();</p><p>  calctensp();</p><p>

94、  stattenvoter();}</p><p>  void menu()</p><p>  {void stat();</p><p>  void check();</p><p><b>  int n,w;</b></p><p><b>  do</b>&

95、lt;/p><p>  {puts("\t\t********************MENU*********************\n\n");</p><p>  puts("\t\t\t\t 1.statistic");</p><p>  puts("\t\t\t\t 2.check_vote"

96、);</p><p>  puts("\t\t\t\t 3.exit");</p><p>  puts("\n\n\t\t ******************************************\n");</p><p>  printf("Choice your number(1-3):[ ]\b\

97、b");</p><p>  scanf("%d",&n);</p><p>  if(n<1||n>3)</p><p><b>  {w=1;</b></p><p>  getchar();}</p><p>  else w=0;

98、}</p><p>  while(w==1);</p><p><b>  switch(n)</b></p><p><b>  {</b></p><p><b>  case 1:</b></p><p><b>  stat();&

99、lt;/b></p><p><b>  break;</b></p><p><b>  case 2:</b></p><p><b>  check();</b></p><p><b>  break;</b></p><

100、p><b>  case 3:</b></p><p><b>  exit(0);</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void menu_vote()</p>

101、<p><b>  {</b></p><p>  void browse_vote();</p><p>  void search_vote();</p><p><b>  int n,w;</b></p><p><b>  do</b></p>

102、<p><b>  {</b></p><p>  puts("\t\t********************MENU*********************\n\n");</p><p>  puts("\t\t\t\t 1.browse_vote");</p><p>  puts(&

103、quot;\t\t\t\t 2.search_vote");</p><p>  puts("\t\t\t\t 3.esc");</p><p>  puts("\n\n\t\t ******************************************\n");</p><p>  printf(&quo

104、t;Choice your number(1-3):[ ]\b\b");</p><p>  scanf("%d",&n);</p><p>  if(n<1||n>3)</p><p><b>  {</b></p><p><b>  w=1;</b&

105、gt;</p><p>  getchar();</p><p><b>  }</b></p><p><b>  else w=0;</b></p><p>  }while(w==1);</p><p><b>  switch(n)</b><

106、;/p><p><b>  {</b></p><p><b>  case 1:</b></p><p>  browse_vote();</p><p><b>  break;</b></p><p><b>  case 2:</b&

107、gt;</p><p>  search_vote();</p><p><b>  break;</b></p><p><b>  case 3:</b></p><p><b>  exit(0);</b></p><p><b>  }

108、</b></p><p><b>  }</b></p><p>  void printf_onevote(int j)</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  prin

109、tf("vote_id:%s\n",vot[j].id);</p><p>  printf("vote_name:%s vote_address:%s\n",vot[j].name,vot[j].address);</p><p>  printf("vote_sporter:");</p><p>

110、;  for(i=0;i<10;i++)</p><p>  printf("%d, ",vot[j].a[i]);</p><p>  printf("\n\n");</p><p><b>  }</b></p><p>  void printf_n_vote(int

111、m)</p><p><b>  {</b></p><p><b>  int j;</b></p><p>  for(j=0;j<m;j++)</p><p>  {if(j%10==0)</p><p>  {printf("\nPass a

112、nykey to continue...");</p><p>  getchar();</p><p>  puts("\n\n");}</p><p>  printf_onevote(j);}</p><p>  getchar();}</p><p>  void print

113、f_back()</p><p><b>  {</b></p><p><b>  int w;</b></p><p>  printf("\n\n\tSuccessful.^_^\n\n");</p><p>  printf("What do you want

114、to do?\n\n\t1).Exit\t2.back: [ ]\b\b");</p><p>  scanf("%d",&w);</p><p>  if(w==1) exit(0);</p><p>  else menu_vote();</p><p><b>  }</b>&

115、lt;/p><p>  void browse_vote()</p><p><b>  {int k;</b></p><p>  k=load_vote();</p><p>  printf_n_vote(k);</p><p>  printf_back();</p><

116、p><b>  }</b></p><p>  void search_vote()</p><p><b>  {</b></p><p>  int m,i,flag=0;</p><p>  char vs[10];</p><p>  printf("

117、please input vot_id:\n");</p><p>  scanf("%s",&vs);</p><p>  m=load_vote();</p><p>  for(i=0;i<m;i++)</p><p><b>  {</b></p><

118、;p>  if(strcmp(vs,vot[i].id)==0)</p><p><b>  {</b></p><p><b>  flag=1;</b></p><p>  printf_onevote(i);</p><p><b>  }</b></p>

119、;<p>  if(flag==1)</p><p>  printf("Found!");</p><p><b>  else </b></p><p>  printf("Not found!");</p><p>  printf_back();</p&

120、gt;<p><b>  }</b></p><p><b>  }</b></p><p>  void check()</p><p>  {int n,w;</p><p><b>  do</b></p><p><b>

121、;  {</b></p><p>  puts("\t\t*********************MENU*********************\n\n");</p><p>  puts("\t\t\t\t 1.browse_vote");</p><p>  puts("\t\t\t\t 2.s

122、earch_vote");</p><p>  puts("\t\t\t\t 3.back");</p><p>  puts("\n\n\t\t *******************************************\n");</p><p>  printf("Choice your n

123、umber(1-3):[ ]\b\b");</p><p>  scanf("%d",&n);</p><p>  if(n<1||n>3)</p><p><b>  {w=1;</b></p><p>  getchar();</p><p&

124、gt;<b>  }</b></p><p><b>  else w=0;</b></p><p>  }while(w==1);</p><p><b>  switch(n)</b></p><p><b>  {case 1:</b></p

125、><p>  browse_vote();</p><p><b>  break;</b></p><p><b>  case 2:</b></p><p>  search_vote();</p><p><b>  break;</b></p&

126、gt;<p><b>  case 3:</b></p><p>  menu();}}</p><p>  void main()</p><p>  {menu();}</p><p><b>  Unit3</b></p><p>  #include

127、 "stdio.h"</p><p>  #include "stdlib.h"</p><p>  #include "string.h"</p><p>  #define N 50</p><p>  struct student //學(xué)生結(jié)構(gòu)

128、體</p><p><b>  {</b></p><p>  char num[11];</p><p>  char name[20];</p><p>  int score[3];</p><p>  float ave;</p><p>  }stu[N];

129、 </p><p>  void printf_one(int i) //輸出一個(gè)學(xué)生的信息</p><p><b>  {</b></p><p><b>  int j;</b></p><p>  printf("%11s %17s"

130、,stu[i].num,stu[i].name);</p><p>  for(j=0;j<3;j++)</p><p>  printf("%9d",stu[i].score[j]);</p><p>  printf("%9.2f\n",stu[i].ave);</p><p><b&g

131、t;  }</b></p><p>  void printf_face() //輸出表頭</p><p><b>  {</b></p><p>  printf("\n\tNO. \t\t name score1 score2 score3 average\n");<

132、;/p><p><b>  }</b></p><p>  void save(int n) //保存所有學(xué)生信息到文件</p><p><b>  {</b></p><p><b>  FILE *fp;</b></p><p&

133、gt;<b>  int i;</b></p><p>  if((fp=fopen("score.txt","wb"))==NULL)</p><p><b>  {</b></p><p>  printf("\nCannot open file\n");&l

134、t;/p><p><b>  }</b></p><p>  for(i=0;i<n;i++)if(stu[i].ave!=0)if(fwrite(&stu[i],sizeof(struct student),1,fp)!=1)printf("file write error\n");</p><p>  fclo

135、se(fp);</p><p><b>  }</b></p><p>  void no_input(int i,int n) //按編號(hào)添加新記錄</p><p><b>  {</b></p><p>  int j,k,w1;</p><p><b&g

136、t;  do{</b></p><p><b>  w1=0;</b></p><p>  printf("NO.:");</p><p>  scanf("%s",&stu[i].num);</p><p>  for(j=0;stu[i].num[j]!=&

137、#39;\0';j++)</p><p>  if(stu[i].num[j]<'0'||stu[i].num[j]>'9')</p><p>  {puts("intput error!Only be made up of(0-9).Please reinput!\n");</p><p> 

138、 w1=1;break;}</p><p><b>  if(w1!=1)</b></p><p>  for(k=0;k<n;k++)</p><p>  if(k!=i&&strcmp(stu[k].num,stu[i].num)==0)</p><p>  {puts("This r

139、ecord is exist.please reinput!\n");</p><p>  w1=1;break;}}</p><p>  while(w1==1);}</p><p>  void score_input(int i) //輸入指定編號(hào)學(xué)生的成績(jī)</p><p><b>  {int j;&l

140、t;/b></p><p>  for(j=0;j<3;j++)</p><p>  {printf("score%d:",j+1);</p><p>  scanf("%d",&stu[i].score[j]);}}</p><p>  void average(int i)

141、 //計(jì)算指定編號(hào)學(xué)生的平均成績(jī)</p><p><b>  {int j;</b></p><p>  float sum;</p><p>  for(sum=0,j=0;j<3;j++)</p><p>  sum+=stu[i].score[j];</p><p>  

142、stu[i].ave=sum/3.0;}</p><p>  void input(int i) //添加一條新記錄</p><p>  {no_input(i,i);</p><p>  printf("name:");</p><p>  scanf("%s",stu[i].

143、name);</p><p>  score_input(i);</p><p>  average(i);}</p><p>  int load () //讀取文件并返回記錄數(shù)</p><p>  {FILE *fp;</p><p><b>  int i;</

144、b></p><p>  if((fp=fopen("score.txt","rb"))==NULL)printf("\nCannot open file!\n");</p><p>  for(i=0;!feof(fp);i++)</p><p>  fread(&stu[i],sizeof

145、(struct student),1,fp);</p><p>  fclose(fp);</p><p>  return(i-1);}</p><p>  void del() //調(diào)用刪除菜單函數(shù)</p><p>  { void menu();</p><p><b&

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(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)論