版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 計(jì)算機(jī)高級(jí)語(yǔ)言課程設(shè)計(jì)報(bào)告</p><p><b> 題目要求</b></p><p><b> 工資信息管理系統(tǒng)</b></p><p><b> 【要求】</b></p><p> 該系統(tǒng)能夠?qū)崿F(xiàn)工資信息管理。系統(tǒng)包括錄入、瀏覽、查詢、統(tǒng)計(jì)等功
2、能。其中錄入功能要求能夠添加新的工資信息到文件;瀏覽功能要求能按照工資卡號(hào)、姓名分類(lèi)瀏覽,提供分屏顯示;有排序功能,排序后按照工資卡號(hào)升序或?qū)嵃l(fā)工資降序輸出;查詢功能要求能夠按照工資卡號(hào)、姓名查詢;統(tǒng)計(jì)功能要求能夠按照月份累計(jì)統(tǒng)計(jì)某職工在某時(shí)間段實(shí)發(fā)工資總金額。</p><p><b> 【提示】</b></p><p> 文件中一行數(shù)據(jù)對(duì)應(yīng)一個(gè)職工工資信息<
3、;/p><p> 工資信息的數(shù)據(jù)結(jié)構(gòu)采用結(jié)構(gòu)體數(shù)組,一個(gè)數(shù)組元素對(duì)應(yīng)一條工資單記錄</p><p> 工資單信息包括工資卡號(hào)、姓名、月份、應(yīng)發(fā)工資、水費(fèi)、電費(fèi)、稅金、實(shí)發(fā)工資等</p><p> 實(shí)發(fā)工資=應(yīng)發(fā)工資-水費(fèi)-電費(fèi)-稅金,其中稅金的計(jì)算方法為</p><p> a. 應(yīng)發(fā)工資<800元,稅金=0</p>
4、<p> b. 800<應(yīng)發(fā)工資<1400元,稅金=(應(yīng)發(fā)工資-800)*5%</p><p> c. 應(yīng)發(fā)工資>1400元,稅金=(應(yīng)發(fā)工資-1400)*10%</p><p> 另: 課程實(shí)習(xí)報(bào)告的參考格式</p><p><b> 題目編號(hào)</b></p><p> 寫(xiě)出
5、系統(tǒng)總設(shè)計(jì)的思路、功能模塊劃分。給出合理的測(cè)試數(shù)據(jù)及運(yùn)行結(jié)果,要求能夠體現(xiàn)程序的正確性和完備性及對(duì)錯(cuò)誤輸入的處理??偨Y(jié)算法或系統(tǒng)的優(yōu)缺點(diǎn),給出算法或系統(tǒng)進(jìn)一步改進(jìn)的設(shè)想。在附錄中給出源代碼,</p><p><b> 附錄</b></p><p><b> 需求分析</b></p><p> 根據(jù)題目要求,由于工資單
6、信息是存放在文件中,所以應(yīng)提供文件的輸入、輸出等操作;在程序中需要瀏覽學(xué)生的信息,應(yīng)提供錄入、瀏覽、查詢、統(tǒng)計(jì)等操作;另外還應(yīng)提供鍵盤(pán)式選擇菜單實(shí)現(xiàn)功能選擇。</p><p><b> 三、 總體設(shè)計(jì)</b></p><p> 根據(jù)上面的需求分析,可以將這個(gè)系統(tǒng)的設(shè)計(jì)分為以下幾個(gè)模塊:數(shù)據(jù)輸入,數(shù)據(jù)添加,數(shù)據(jù)瀏覽,數(shù)據(jù)查詢,數(shù)據(jù)統(tǒng)計(jì)。</p>&l
7、t;p> 圖一 系統(tǒng)功能模塊圖</p><p><b> 四、詳細(xì)設(shè)計(jì)</b></p><p><b> 1.主函數(shù)</b></p><p> 主函數(shù)提供輸入、處理和輸出部分的函數(shù)調(diào)用。其中各功能模塊用菜單方式選擇。</p><p><b> [流程圖]</b>
8、;</p><p> 圖二 主函數(shù)模塊功能流程圖</p><p><b> [程序]</b></p><p> main() /********************主函數(shù)**********************/</p><p><b> { </b></p>
9、;<p> int n,w; /*變量n保存選擇菜單數(shù)字,w判斷輸入的數(shù)字是否在功能菜單應(yīng)對(duì)數(shù)字的范圍內(nèi)*/</p><p> do{ puts("\t\t\t******************主菜單***************\n\n");</p><p> printf("\t\t\t\t 1.錄入工資信息: \n&quo
10、t;);</p><p> printf("\t\t\t\t 2.添加工資信息: \n");</p><p> printf("\t\t\t\t 3.瀏覽工資信息: \n");</p><p> printf("\t\t\t\t 4.查詢工資信息: \n");</p><p>
11、 printf("\t\t\t\t 5.統(tǒng)計(jì)工資信息: \n");</p><p> printf("\t\t\t\t 6.退出系統(tǒng): \n");</p><p> puts("\n\n\t\t\t***************************************\n");</p><p>
12、; printf("選擇(1-6):[ ]\b\b");</p><p> scanf("%d",&n);</p><p> if(n<1||n>6) {w=1;getchar();}</p><p> else w=0;} /*對(duì)選擇的數(shù)字作判斷*/</p><p>
13、 while (w==1);</p><p><b> switch(n)</b></p><p> { case 1: enter();break; /*輸入模塊*/</p><p> case 2: add();break; /*添加模塊*/</p><p> case 3: browse();br
14、eak; /*瀏覽模塊*/</p><p> case 4: search();break; /*查詢模塊*/</p><p> case 5: count();break; /*統(tǒng)計(jì)模塊*/</p><p> case 6: exit(0);break; /*退出*/</p><p><b> } &l
15、t;/b></p><p><b> }</b></p><p><b> 2.各功能模塊設(shè)計(jì)</b></p><p><b> ?。?)輸入函數(shù)</b></p><p><b> 【分析】</b></p><p>
16、單獨(dú)看各數(shù)據(jù)信息,姓名是字符型,可以采用字符型數(shù)組;工資卡號(hào)和月份是整數(shù),采用整型;實(shí)發(fā)工資,水費(fèi),電費(fèi),稅金,應(yīng)發(fā)工資有可能是小數(shù)可采用實(shí)型。數(shù)據(jù)信息存放在文件中,一條記錄對(duì)應(yīng)一個(gè)職工的工資單信息,既符合習(xí)慣也方便信息管理。同時(shí)把職工的工資卡號(hào),姓名,月份,應(yīng)發(fā)工資,水費(fèi),電費(fèi),稅金,實(shí)發(fā)工資作為結(jié)構(gòu)體成員,用結(jié)構(gòu)體數(shù)組存放若干個(gè)職工的工資信息。</p><p> struct gz</p>
17、<p> { int num;</p><p> char name[20];</p><p> int month;</p><p><b> long ys;</b></p><p><b> long ss;</b></p><p><b&
18、gt; long wf;</b></p><p><b> long ef;</b></p><p> long tax;</p><p> } g[N]; /*g[N]中每個(gè)數(shù)組元素對(duì)應(yīng)一份工資資料*/</p><p><b> 【流程圖】</b></p>
19、;<p><b> 【程序】</b></p><p><b> enter()</b></p><p> { int i,n;</p><p> printf("共輸入多少份工資信息 (0-%d)?:",N-1); 圖三 輸入模塊流程圖</p>
20、<p> scanf("%d",&n);</p><p> printf("\n 現(xiàn)在開(kāi)始錄入... \n\n");</p><p> for(i=0;i<n;i++)</p><p> {printf("\n第 %d 份工資信息:工資卡號(hào) 姓名 月份 應(yīng)發(fā)工資 水費(fèi) 電費(fèi)\n&qu
21、ot;,i+1);</p><p> input(i);}</p><p><b> sort();</b></p><p> if(i!=0) save(n);</p><p> printf_back();</p><p><b> }</b></p>
22、;<p><b> ?。?)添加模塊</b></p><p><b> 【分析】</b></p><p> 該模塊的功能是用戶需要增加新的職工工資信息記錄,從鍵盤(pán)輸入并逐條寫(xiě)入到原來(lái)的輸入文件中,注意采用追加而不是覆蓋的方式。</p><p><b> 【流程圖】</b></
23、p><p><b> 【程序】</b></p><p><b> add()</b></p><p> { int i,n,m,k;</p><p><b> FILE *fp;</b></p><p><b> n=load();<
24、;/b></p><p> printf("要添加多少份信息?(0-%d):",N-n-1);</p><p> scanf("%d",&m);</p><p><b> k=m+n;</b></p><p> for(i=n;i<k;i++)</
25、p><p> {printf("\n請(qǐng)輸入信息:工資卡號(hào) 姓名 月份 應(yīng)發(fā)工資 水費(fèi) 電費(fèi)\n",i-n+1);</p><p><b> input(i);</b></p><p> } 圖四 添加模塊流程圖</p
26、><p><b> sort();</b></p><p><b> save(k);</b></p><p> printf_back();</p><p><b> }</b></p><p><b> ?。?)瀏覽模塊</b&g
27、t;</p><p><b> 【分析】</b></p><p> 該模塊的功能是顯示所有職工工資信息記錄。</p><p><b> 【流程圖】</b></p><p> 圖五 瀏覽模塊流程圖</p><p><b> 【程序】</b><
28、;/p><p><b> browse()</b></p><p> { int i,n;</p><p><b> n=load();</b></p><p> printf_face();</p><p> for(i=0;i<n;i++)</p>
29、<p> { if(i%10==0) {printf("\n\nPass any key to contiune...");</p><p> getch(); puts("\n\n");}</p><p> printf_one(i); printf("\n");</p><p>&
30、lt;b> }</b></p><p> printf("\tThere are %d record.\n",n);</p><p> printf("\nPass any key to back....");</p><p><b> getch();</b></p&g
31、t;<p><b> menu();</b></p><p><b> }</b></p><p><b> 查詢模塊</b></p><p> 【分析】分為兩個(gè)子模塊:安姓名查找模塊和按卡號(hào)查詢模塊</p><p><b> 【流程圖】<
32、;/b></p><p><b> 【程序】</b></p><p><b> search()</b></p><p><b> { </b></p><p><b> int n; </b></p><p><
33、;b> while(1) </b></p><p><b> { </b></p><p> printf("\n1. 按照卡號(hào)查詢: \n "); </p><p> printf("\n2. 按照姓名查詢: \n "); <
34、/p><p> printf("\n0. 返回主菜單: \n");</p><p> scanf("%d",&n);</p><p> switch(n) </p><p><b> { </b></p><p> case 1:search
35、_num();break; </p><p> case 2:search_name();break; </p><p> case 0:menu();break; </p><p><b> } </b></p><p><b> } </b></p><p>&l
36、t;b> }</b></p><p> ?。?)按姓名查找模塊</p><p><b> 【分析】</b></p><p> 該模塊的功能是根據(jù)輸入的職工姓名查找對(duì)應(yīng)的工資信息記錄。</p><p><b> 【流程圖】</b></p><p>
37、圖六 按姓名查找模塊流程圖</p><p><b> 【程序】</b></p><p> search_name()</p><p> { int i,n,k,w1=1;</p><p> struct gz s;</p><p><b> n=load();</b&
38、gt;</p><p><b> do</b></p><p><b> { k=-1;</b></p><p> printf("\n\nEnter name that you want to search! name");</p><p> scanf(&quo
39、t;%s",s.name);</p><p> printf_face();</p><p> for(i=0;i<n;i++)</p><p> if(strcmp(s.name,g[i].name)==0)</p><p> {k=i; printf_one(k);}</p><p>&l
40、t;b> if(k==-1)</b></p><p> {printf("\n\nNo exist!please");</p><p> printf("\n\nAre you again?\n\t 1).Again 2)No and back [ ]\b\b ");</p><p> scanf(&
41、quot;%d",&w1);}</p><p> }while(k==-1&&w1==1);</p><p><b> menu();</b></p><p><b> }</b></p><p> ?。?)按工資卡號(hào)查找模塊</p><p
42、><b> 【分析】</b></p><p> 該模塊的功能是根據(jù)輸入的職工工資卡號(hào)查找對(duì)應(yīng)的工資信息記錄。</p><p><b> 【流程圖】</b></p><p> 圖七 按工資卡號(hào)查找模塊流程圖</p><p><b> 【程序】</b></p
43、><p> search_num()</p><p> { int i,n,k,w1=1;</p><p> struct gz s;</p><p><b> n=load();</b></p><p><b> do</b></p><p>
44、<b> { k=-1;</b></p><p> printf("\n\nEnter number that you want to search! number");</p><p> scanf("%d",&s.num);</p><p> printf_face();<
45、/p><p> for(i=0;i<n;i++)</p><p> if(s.num==g[i].num)</p><p> {k=i; printf_one(k);}</p><p><b> if(k==-1)</b></p><p> {printf("\n\nNo
46、exist!please");</p><p> printf("\n\nAre you again?\n\t 1).Again 2)No and back [ ]\b\b ");</p><p> scanf("%d",&w1);}</p><p> }while(k==-1&&w1=
47、=1);</p><p><b> menu();</b></p><p><b> }</b></p><p><b> ?。?)統(tǒng)計(jì)模塊</b></p><p><b> 【分析】</b></p><p> 該模塊的功能
48、是根據(jù)用戶輸入的職工姓名和所統(tǒng)計(jì)的月份來(lái)計(jì)算得出某個(gè)時(shí)間段的工資總額。</p><p><b> 【流程圖】</b></p><p> 圖八 統(tǒng)計(jì)模塊流程圖</p><p><b> 【程序】</b></p><p><b> count()</b></p>
49、;<p> {int i,j,k,n,sum=0;</p><p> char name[20];</p><p><b> n=load();</b></p><p> printf("\nEnter the enployer's name: [ ]\t\t");</p>
50、<p> scanf("%s",name);</p><p> printf("\nEnter the first month to count! month: [ ]\t\t");</p><p> scanf("%d",&j);</p><p> printf("
51、\nEnter the last month to count! month: [ ]\t\t");</p><p> scanf("%d",&k);</p><p> for(i=0;i<n;i++)</p><p> if(strcmp(name,g[i].name)==0&&g[i].mon
52、th>=j&&g[i].month<=k)</p><p> {printf_one(i);</p><p> sum=sum+g[i].ss;}</p><p> printf("\nthe result of count: sum=%d\n",sum);</p><p><b&
53、gt; menu();</b></p><p><b> }</b></p><p><b> 3.公共函數(shù)</b></p><p> ?。?)排序函數(shù)sort()</p><p><b> 【程序】</b></p><p><
54、b> sort()</b></p><p><b> {</b></p><p> int i,j,n;</p><p> struct gz t;</p><p><b> n=load();</b></p><p> for(i=0;i<
55、;n;i++)</p><p> for(j=i+1;j<n;j++)</p><p> if(g[i].num>g[j].num)</p><p><b> {t=g[i];</b></p><p> g[i]=g[j];</p><p><b> g[j]=t;
56、}</b></p><p><b> }</b></p><p> ?。?)輸入函數(shù)input (int i)</p><p><b> 【程序】</b></p><p> input (int i)</p><p> { scanf("%d%s
57、%d%ld%ld%ld",&g[i].num,g[i].name,&g[i].month,&g[i].ys,&g[i].wf,&g[i].ef);</p><p><b> tax(i);</b></p><p><b> }</b></p><p> ?。?)保存函數(shù)
58、save(int n)</p><p><b> 【程序】</b></p><p> save(int n)</p><p> { FILE *fp;</p><p><b> int i;</b></p><p> if((fp=fopen("salar
59、y.txt","w"))==NULL)</p><p> { printf("\nCannot open file\n");</p><p> return NULL;}</p><p> for(i=0;i<n;i++)</p><p> if(g[i].num!=0)<
60、/p><p> if(fwrite(&g[i],sizeof(struct gz),1,fp)!=1)</p><p> printf("file write error\n");</p><p> fclose(fp);</p><p><b> }</b></p><
61、;p> ?。?)稅金計(jì)算函數(shù)tax( int i)</p><p><b> 【程序】</b></p><p> tax( int i)</p><p><b> {</b></p><p> if(g[i].ys<800) g[i].tax=0;</p><
62、p> else if(800<g[i].ys&&g[i].ys<1400) g[i].tax=((g[i].ys-800)*5/100);</p><p> else g[i].tax=((g[i].ys-1400)*5/100);</p><p> g[i].ss=g[i].ys-g[i].wf-g[i].
63、ef-g[i].tax;</p><p><b> }</b></p><p> ?。?)加載函數(shù)load()</p><p><b> 【程序】</b></p><p><b> load()</b></p><p> { FILE *fp;&
64、lt;/p><p><b> int i;</b></p><p> if((fp=fopen("salary.txt","r"))==NULL)</p><p> {printf("\nCannot open file\n");</p><p> retu
65、rn NULL;}</p><p> for(i=0;!feof(fp);i++)</p><p> fread(&g[i],sizeof(struct gz),1,fp);</p><p> fclose(fp);</p><p> return(i-1);</p><p><b> }&
66、lt;/b></p><p> ?。?)顯示數(shù)據(jù)結(jié)構(gòu)項(xiàng)目的函數(shù)printf_face()</p><p> printf_face()</p><p> { printf("\n num name month ys wf ef ss tax \n")
67、;}</p><p> (7)顯示一個(gè)記錄的函數(shù)</p><p> printf_one(int i)</p><p> { printf("%5d%10s%5d%10ld%10ld%10ld%10ld%10ld",g[i].num,g[i].name,g[i].month,</p><p> g[i].ys,g[
68、i].wf,g[i].ef,g[i].ss,g[i].tax);}</p><p> (8)一個(gè)任務(wù)結(jié)束時(shí)的選擇瀏覽還是返回的函數(shù)</p><p> printf_back()</p><p> { int k,w;</p><p> printf("\n\n\tSuccessful.\n\n");</p&g
69、t;<p> printf("What do you want to do?\n\n\t 1).Browse all now 2).Back;[ ]\b\b");</p><p> scanf("%d",&w);</p><p> else menu();</p><p> if(w==1) br
70、owse();</p><p><b> }</b></p><p><b> 五、上機(jī)操作</b></p><p><b> 1.?dāng)?shù)據(jù)源</b></p><p> 2.編譯、連接和運(yùn)行</p><p><b> 3.結(jié)果</b
71、></p><p> 下面是各個(gè)模塊的界面圖</p><p><b> 主菜單函數(shù)</b></p><p><b> 輸入模塊</b></p><p> 在主界面出現(xiàn)后輸入1回車(chē)看到下圖</p><p><b> 添加模塊</b><
72、/p><p><b> 瀏覽模塊</b></p><p><b> 查找模塊</b></p><p><b> 按工資卡號(hào)查找模塊</b></p><p> (7)按照姓名查找模塊</p><p><b> 統(tǒng)計(jì)模塊</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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 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)
- 工資信息管理系統(tǒng)課程設(shè)計(jì)
- 管理信息系統(tǒng)課程設(shè)計(jì)---企業(yè)工資信息管理系統(tǒng)
- 數(shù)據(jù)庫(kù)系統(tǒng)課程設(shè)計(jì)---工資信息管理系統(tǒng)
- 數(shù)據(jù)庫(kù)系統(tǒng)課程設(shè)計(jì)--工資信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--職工信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--- 學(xué)生信息管理系統(tǒng)
- 職工信息管理系統(tǒng)c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)——學(xué)生信息管理系統(tǒng)
- 教師信息管理系統(tǒng)(c語(yǔ)言課程設(shè)計(jì))
- c語(yǔ)言課程設(shè)計(jì)---學(xué)生信息管理系統(tǒng)
- 學(xué)生信息管理系統(tǒng)-c語(yǔ)言課程設(shè)計(jì)
- c語(yǔ)言課程設(shè)計(jì)——歌曲信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)職工信息管理系統(tǒng)
- c語(yǔ)言課程信息管理系統(tǒng)課程設(shè)計(jì)報(bào)告
- c語(yǔ)言課程設(shè)計(jì)報(bào)告課程信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)---學(xué)生信息管理系統(tǒng)
- c語(yǔ)言課程設(shè)計(jì)--學(xué)生信息管理系統(tǒng)
評(píng)論
0/150
提交評(píng)論