版權(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- c語(yǔ)言課程設(shè)計(jì)論文--銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)----銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)-銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)報(bào)告---銷售管理系統(tǒng)
- 服裝銷售管理系統(tǒng)—c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)銷售管理系統(tǒng)報(bào)告
- c語(yǔ)言課程設(shè)計(jì)銷售管理系統(tǒng)報(bào)告
- c語(yǔ)言課程設(shè)計(jì)銷售管理系統(tǒng)報(bào)告
- c語(yǔ)言課程設(shè)計(jì)-服裝銷售系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)----服裝銷售系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)-教材管理系統(tǒng)——課程論文
- c語(yǔ)言程序課程設(shè)計(jì)報(bào)告-圖書銷售管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)報(bào)告—服裝銷售系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)(論文)-購(gòu)物卡管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)報(bào)告——《商品銷售管理》
- 銷售管理系統(tǒng)c++課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論