課程設計---職工工資管理系統(tǒng)_第1頁
已閱讀1頁,還剩36頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、<p><b>  目 錄</b></p><p>  一、需求分析··························

2、;···············2</p><p>  二、概要設計················

3、83;························2</p><p>  三、詳細設計·······&

4、#183;·································5</p><

5、p>  四、調(diào)試分析··································

6、83;······18</p><p>  五、用戶手冊·························

7、················19</p><p>  六、測試數(shù)據(jù)···············

8、83;·························19</p><p>  七、附錄······&#

9、183;····································

10、··23</p><p><b>  需求分析</b></p><p><b>  職工工資管理系統(tǒng) </b></p><p><b>  功能設計要求 </b></p><p>  (1)輸入記錄:將每一個職工的姓名、ID號以及基本工資、職務工資、崗位津貼

11、、醫(yī)療保險、公積金的數(shù)據(jù)作為一個記錄。該軟件能建立一個新的數(shù)據(jù)文件或給已建立好的數(shù)據(jù)文件增加記錄。</p><p>  (2)顯示記錄:根據(jù)用戶提供的記錄或者根據(jù)職工姓名顯示一個或幾個職工的各項工資和平均工資。</p><p> ?。?)修改記錄:可以對數(shù)據(jù)文件的任意記錄的數(shù)據(jù)進行修改并在修改前后對記錄內(nèi)容進行顯示。</p><p> ?。?)查找記錄:可以對數(shù)據(jù)

12、文件的任意記錄的數(shù)據(jù)進行查找并在查找前后對記錄內(nèi)容進行顯示。 </p><p> ?。?)刪除記錄:可刪除數(shù)據(jù)文件中的任一記錄。 </p><p> ?。?) 統(tǒng)計: (A)計算各項工資平均工資及總工資, (B)統(tǒng)計符合指定條件(如職工工資前三項之和在3000元以上、3000~2000元、2000~1000元) 以內(nèi)的工資職工人數(shù)及占總職工人數(shù)的百分比。(C)按字符表格形式打印全部職工工

13、資信息表及平均工資(包括各項總的平均工資)。 </p><p> ?。?)保存數(shù)據(jù)文件功能。 </p><p>  例如:職工工資信息表 ID號 姓名 基本工資 職務工資 津貼 醫(yī)療保險- 公積金- 總工資 01 張望 1286 794 198 109 135 2034 02 李明 1185 628 135 94 114 1740 03 王

14、小民 895 438 98 64 73 1294 04 張效章 1350 868 210 116 150 2162 05 彭山 745 398 84 61 68 1098 各項平均工資 1092.2 625.2 145 88.8 108</p><p>  (要求:1.源文件采用多文件的工程結構2.數(shù)據(jù)存儲采用文件形式3.標準的C輸入

15、輸出4.功能完善,適當?shù)淖⑨專?.關于文件的內(nèi)容需要自學)</p><p><b>  二、概要設計</b></p><p>  1、程序總體功能框架:</p><p>  2、一些數(shù)據(jù)結構的介紹:</p><p>  struct worker 定義職工的結構體</p><p><

16、;b>  {</b></p><p>  int num; 職工工號</p><p>  char name[20]; 職工姓名</p><p>  int jibengongzi; 職工的基本工資</p><p>  int zhiwugongzi; 職工的職務工資<

17、;/p><p>  int jintie; 職工的津貼</p><p>  int yiliaobaoxian; 職工的醫(yī)療保險</p><p>  int gongjijin; 職工的公積金</p><p>  int qiansan; 職工前三項工資(基本工資、職務工資、津貼)之和</p>

18、;<p>  int sum; 職工的總工資</p><p>  }worker[100]; 建立最多為100,、名為worker的結構體</p><p>  3、定義主要的函數(shù):</p><p>  void menu();</p><p>  void Input();</p>&

19、lt;p>  void Modify();</p><p>  void Search();</p><p>  void Add();</p><p>  void Delete();</p><p>  void Show();</p><p>  void Exit();</p><p&

20、gt;  4、幾個主要函數(shù)介紹:</p><p>  清屏函數(shù):system("cls"); 將前面操作的屏幕清楚,但不會清除數(shù)據(jù)</p><p>  菜單函數(shù):menu(); 顯示主菜單,便于選擇</p><p>  輸入函數(shù):Input(); 用于輸入數(shù)據(jù)</p><p>  修改函數(shù):Modify();

21、 用于修改數(shù)據(jù)</p><p>  查找函數(shù):Search(); 用于查找信息</p><p>  添加函數(shù):Add(); 用于增加信息</p><p>  刪除函數(shù):Delete(); 用于刪除信息</p><p>  顯示函數(shù):Show(); 用于顯示信息</p><p>  退出函數(shù)

22、:Exit(); 用于退出該系統(tǒng)</p><p>  選擇函數(shù):select(); 用于選擇顯示信息或返回到菜單</p><p>  保存信息的函數(shù):save(): 用于保存信息</p><p>  保存人數(shù)的函數(shù):P(); 用于保存已保存數(shù)據(jù)的人數(shù)</p><p><b>  5、本程序模塊結構<

23、/b></p><p><b>  ⑴ 主函數(shù)模塊</b></p><p>  int main()</p><p><b>  {</b></p><p>  system("cls");</p><p><b>  menu();<

24、;/b></p><p><b>  }</b></p><p>  執(zhí)行主函數(shù)后,執(zhí)行菜單函數(shù)。 </p><p><b>  ⑵菜單函數(shù)模塊</b></p><p>  void menu()</p><p><b>  {</b></p

25、><p><b>  int n;</b></p><p>  system("cls");</p><p>  printf("\n\n\n");</p><p>  printf("\t\t*****************************************

26、******\n");</p><p>  printf("\t\t** **\n");</p><p>  printf("\t\t** If you were the first to enter the system **\n");</p>

27、<p>  printf("\t\t** please select Input! **\n");</p><p>  printf("\t\t** **\n");</p><p>  printf("

28、\t\t** 1-------Input **\n");</p><p>  printf("\t\t** 2-------Modify **\n");</p><p>  printf("\t\t** 3------

29、-Search **\n");</p><p>  printf("\t\t** 4-------Add **\n");</p><p>  printf("\t\t** 5-------Delete **\

30、n");</p><p>  printf("\t\t** 6-------Show **\n");</p><p>  printf("\t\t** 7-------Exit **\n");</p><p

31、>  printf("\t\t** **\n");</p><p>  printf("\t\t***********************************************\n");</p><p>  printf("\t\t\n&

32、quot;);</p><p>  printf("\n\n");</p><p>  printf("\t\tInput your choose(1-7):");</p><p>  scanf("%d",&n);</p><p>  if(n>=1&&

33、;n<=7)</p><p><b>  {</b></p><p><b>  switch(n)</b></p><p><b>  {</b></p><p>  case 1:Input();break;</p><p>  case 2:

34、Modify();break;</p><p>  case 3:Search();break;</p><p>  case 4:Add();break;</p><p>  case 5:Delete();break;</p><p>  case 6:Show();break;</p><p>  case 7:

35、Exit();break;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  else</b></p><p><b>  menu();</b></p><p><b

36、>  }</b></p><p>  菜單函數(shù)中包括輸入函數(shù)、修改函數(shù)、查找函數(shù)、添加函數(shù)、刪除函數(shù)、顯示函數(shù)、退出函數(shù)。根據(jù)菜單中各個函數(shù)代表的數(shù)字選擇相應的數(shù)字進行操作。</p><p><b>  詳細設計</b></p><p>  #include "stdio.h"</p><

37、;p>  #include "string.h"</p><p>  struct worker //定義結構體</p><p><b>  {</b></p><p><b>  int num;</b></p><p>  char name[20];&l

38、t;/p><p>  int jibengongzi;</p><p>  int zhiwugongzi;</p><p>  int jintie;</p><p>  int yiliaobaoxian;</p><p>  int gongjijin;</p><p>  int qians

39、an;</p><p><b>  int sum;</b></p><p>  } worker[100];</p><p>  void menu(); //定義幾個主要的函數(shù)</p><p>  void Input();</p><p>  void Modify();<

40、/p><p>  void Search();</p><p>  void Add();</p><p>  void Delete();</p><p>  void Show();</p><p>  void Exit();</p><p>  int main() //主函數(shù)&

41、lt;/p><p><b>  {</b></p><p>  system("cls");</p><p><b>  menu();</b></p><p><b>  }</b></p><p>  void menu()

42、 //菜單函數(shù)</p><p><b>  {</b></p><p><b>  int n;</b></p><p>  system("cls"); //清屏</p><p>  printf("\n\n\n"); //菜單界面</

43、p><p>  printf("\t\t***********************************************\n");</p><p>  printf("\t\t** **\n");</p><p>  printf(&

44、quot;\t\t** If you were the first to enter the system **\n");</p><p>  printf("\t\t** please select Input! **\n");</p><p>  printf("\t\t**

45、 **\n");</p><p>  printf("\t\t** 1-------Input **\n");</p><p>  printf("\t\t** 2-------Mo

46、dify **\n");</p><p>  printf("\t\t** 3-------Search **\n");</p><p>  printf("\t\t** 4-------Add

47、 **\n");</p><p>  printf("\t\t** 5-------Delete **\n");</p><p>  printf("\t\t** 6-------Show **\n");</p&g

48、t;<p>  printf("\t\t** 7-------Exit **\n");</p><p>  printf("\t\t** **\n");</p><p>  printf(&

49、quot;\t\t***********************************************\n");</p><p>  printf("\t\t\n");</p><p>  printf("\n\n");</p><p>  printf("\t\tInput your choos

50、e(1-7):"); //選擇需要進行的功能,選擇1-7之間的數(shù)</p><p>  scanf("%d",&n);</p><p>  if(n>=1&&n<=7)</p><p><b>  {</b></p><p>  switch(n)

51、//根據(jù)選擇不同的數(shù),實現(xiàn)不同的功能</p><p><b>  {</b></p><p>  case 1:Input();break;</p><p>  case 2:Modify();break;</p><p>  case 3:Search();break;</p><p>  ca

52、se 4:Add();break;</p><p>  case 5:Delete();break;</p><p>  case 6:Show();break;</p><p>  case 7:Exit();break;</p><p><b>  }</b></p><p><b>

53、;  }</b></p><p><b>  else</b></p><p>  menu(); //如果選擇的數(shù)不在1至7之間,返回菜單重新輸入</p><p><b>  }</b></p><p>  void Input() //輸入函數(shù)</p><

54、;p><b>  {</b></p><p><b>  int i,p;</b></p><p><b>  clrscr();</b></p><p>  printf("\n\nHow many people?(0-100):"); //輸入需要輸入信息的職工人數(shù)&l

55、t;/p><p>  scanf("%d",&p);</p><p>  if(p>=0&&p<=100) //輸入職工的信息</p><p><b>  {</b></p><p>  printf("\n\n");</p>&l

56、t;p>  printf("Please input data:\n");</p><p>  printf("\n");</p><p><b>  f1();</b></p><p>  for(i=0;i<p;i++)</p><p><b>  {&l

57、t;/b></p><p><b>  input(i);</b></p><p>  worker[i].sum=worker[i].jibengongzi+worker[i].zhiwugongzi</p><p>  +worker[i].jintie-worker[i].yiliaobaoxian-worker[i].gongji

58、jin; //計算職工的總工資</p><p>  worker[i].qiansan=worker[i].jibengongzi+worker[i].zhiwugongzi+worker[i].jintie; //職工前三項工資(基本工資、職務工資、津貼)之和</p><p><b>  }</b></p><p><b>

59、;  }</b></p><p><b>  else</b></p><p>  Input(); //如果輸入的職工人數(shù)超過100,返回輸入函數(shù)重新輸入</p><p>  save(p); //保存輸入的職工信息</p><p>  select(); //選擇顯示信息或返回到菜單&l

60、t;/p><p><b>  }</b></p><p>  void Modify() //修改函數(shù)</p><p><b>  {</b></p><p>  int i,j=-1,d,k,t,n;char m[20];</p><p>  FILE *fp; //定

61、義一個文件指針</p><p>  system("cls"); //清屏</p><p><b>  n=P();</b></p><p>  printf("\n\n");</p><p>  printf("Choose the way you want to

62、modify:\n"); //選擇通過何種方式修改信息</p><p>  printf("\n\n"); //選擇方式的界面</p><p>  printf("\t\t****************************************\n");</p><p>  printf("\

63、t\t* *\n");</p><p>  printf("\t\t* 1.By name to modify *\n");</p><p>  printf("\t\t*

64、 *\n");</p><p>  printf("\t\t* 2.By number to modify *\n");</p><p>  printf("\t\t* *\n");</p><p>  

65、printf("\t\t****************************************\n");</p><p>  printf("\ninput your selection:");</p><p>  scanf("%d",&d);</p><p>  if(d!=1&

66、;&d!=2)</p><p><b>  {</b></p><p>  printf("\ninput error! Press any key to continue.");</p><p>  getchar();</p><p>  Modify(); //選擇的數(shù)字錯誤,返回修

67、改函數(shù)重新選擇</p><p><b>  }</b></p><p>  else if(d==1)</p><p><b>  {</b></p><p><b>  do</b></p><p><b>  {</b><

68、/p><p>  printf("\nPlease input the name:"); //輸入需要修改職工的姓名</p><p>  scanf("%s",m);</p><p>  for(i=0;i<n;i++)</p><p>  if(strcmp(m,worker[i].name)==

69、0)</p><p><b>  j=i;</b></p><p><b>  if(j==-1)</b></p><p>  printf("\nNot find!Please input again!\n"); //沒有找到該職工,重新輸入</p><p><b>

70、  }</b></p><p>  while(j==-1);</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p><b>  do</

71、b></p><p><b>  {</b></p><p>  printf("\nPlease input the num:"); //輸入需要修改職工的工號</p><p>  scanf("%d",&k);</p><p>  for(i=0;i<n;

72、i++)</p><p>  if(k==worker[i].num)</p><p><b>  j=i;</b></p><p><b>  if(j==-1)</b></p><p>  printf("\nNot find!Please again!\n"); //沒有找

73、到該職工,重新輸入</p><p><b>  }</b></p><p>  while(j==-1);</p><p><b>  }</b></p><p>  printf("\nWhat do you want to modify?\n\n"); //需要修改信息的界

74、面</p><p>  printf("\t\t**************************************\n");</p><p>  printf("\t\t* *\n");</p><p>  printf("\t\t*

75、1.name 2.number *\n");</p><p>  printf("\t\t* *\n");</p><p>  printf("\t\t* 3.jibengongzi 4.zhiwugongzi *\n&qu

76、ot;);</p><p>  printf("\t\t* *\n");</p><p>  printf("\t\t* 5.jintie 6.yiliaobaoxian *\n");</p><p>  printf(&quo

77、t;\t\t* *\n");</p><p>  printf("\t\t* 7.gongjijin *\n");</p><p>  printf("\t\t*

78、 *\n");</p><p>  printf("\t\t**************************************\n");</p><p>  printf("\nPlease input your selection:"); //選擇需要修改的信息</p><p>  scanf(&quo

79、t;%d",&t);</p><p>  switch(t) //通過選擇的數(shù)字,實現(xiàn)修改該信息</p><p><b>  {</b></p><p>  case 1:printf("\nbefore modify:%s",worker[j].name);</p><p> 

80、 printf("\nchange to:");</p><p>  scanf("%s",worker[j].name);</p><p>  printf("\nafter modify:%s",worker[j].name);break;</p><p>  case 2:printf("\

81、nbefore modify:%d",worker[j].num);</p><p>  printf("\nchange to:");</p><p>  scanf("%d",&worker[j].num);</p><p>  printf("\nafter modify:%d",w

82、orker[j].num);break;</p><p>  case 3:printf("\nbefore modify:%d",worker[j].jibengongzi);</p><p>  printf("\nchange to:");</p><p>  scanf("%d",&work

83、er[j].jibengongzi);</p><p>  printf("\nafter modify:%d",worker[j].jibengongzi);break;</p><p>  case 4:printf("\nbefore modify:%d",worker[j].zhiwugongzi);</p><p>

84、  printf("\nchange to:");</p><p>  scanf("%d",&worker[j].zhiwugongzi);</p><p>  printf("\nafter modify:%d",worker[j].zhiwugongzi);break;</p><p>  c

85、ase 5:printf("\nbefore modify:%d",worker[j].jintie);</p><p>  printf("\nchange to:");</p><p>  scanf("%d",&worker[j].jintie);</p><p>  printf("

86、;\nafter modify:%d",worker[j].jintie);break;</p><p>  case 6:printf("\nbefore modify:%d",worker[j].yiliaobaoxian);</p><p>  printf("\nchange to:");</p><p> 

87、 scanf("%d",&worker[j].yiliaobaoxian);</p><p>  printf("\nafter modify:%d",worker[j].yiliaobaoxian);break;</p><p>  case 7:printf("\nbefore modify:%d",worker[j]

88、.gongjijin);</p><p>  printf("\nchange to:");</p><p>  scanf("%d",&worker[j].gongjijin);</p><p>  printf("\nafter modify:%d",worker[j].gongjijin);b

89、reak;</p><p>  default:printf("Error!choice again!!\n");break;</p><p><b>  }</b></p><p>  getchar();</p><p>  printf("\n");</p>&

90、lt;p><b>  f2();</b></p><p>  worker[j].sum=worker[j].jibengongzi+worker[j].zhiwugongzi+worker[j].jintie</p><p>  -worker[j].yiliaobaoxian-worker[j].gongjijin; //職工的總工資</p>

91、<p>  output(j);</p><p>  printf("\nSave it?\n\n1.Yes 2.No\n"); //詢問是否保存修改后的信息</p><p>  scanf("%d",&i);</p><p><b>  if(i==1)</b></p>

92、<p>  save(n); //保存修改后的信息</p><p>  printf("\nPress any key to back!"); //返回到菜單</p><p>  getchar();</p><p><b>  menu();</b></p><p><b&

93、gt;  }</b></p><p>  void Search() //查找函數(shù)</p><p><b>  {</b></p><p>  int i,j=-1,k,d,n;char m[20];</p><p><b>  n=P();</b></p><p

94、>  system("cls"); //清屏</p><p>  printf("Choose the way you want to search:\n"); //選擇通過何種方式查找信息</p><p>  printf("\n\n"); //選擇方式的界面</p><p>  pri

95、ntf("\t\t****************************************\n");</p><p>  printf("\t\t* *\n");</p><p>  printf("\t\t* 1.By name to search

96、 *\n");</p><p>  printf("\t\t* *\n");</p><p>  printf("\t\t* 2.By number to search *\n");</p>

97、<p>  printf("\t\t* *\n");</p><p>  printf("\t\t****************************************\n");</p><p>  printf("\n\n");&l

98、t;/p><p>  printf("Please input your selection:"); //選擇查找的方式</p><p>  scanf("%d",&d);</p><p><b>  if(d==2)</b></p><p><b>  {<

99、/b></p><p><b>  do</b></p><p><b>  {</b></p><p>  printf("\nPlease input the number:"); //輸入需要查找的職工工號</p><p>  scanf("%d"

100、;,&k);</p><p>  for(i=0;i<n;i++)</p><p><b>  {</b></p><p>  if(k==worker[i].num)</p><p><b>  j=i;</b></p><p><b>  }<

101、;/b></p><p><b>  if(j==-1)</b></p><p>  printf("Not find!Please input again!\n"); //沒有找到該職工,重新輸入</p><p><b>  }</b></p><p>  while(

102、j==-1);</p><p>  printf("\n");</p><p><b>  f2();</b></p><p>  output(j); //輸出信息</p><p><b>  }</b></p><p>  else if(d==

103、1)</p><p><b>  {</b></p><p><b>  do</b></p><p><b>  {</b></p><p>  printf("\nPlease input the name:"); //輸入需要查找的職工姓名<

104、/p><p>  scanf("%s",m);</p><p>  for(i=0;i<n;i++)</p><p>  if(strcmp(m,worker[i].name)==0)</p><p><b>  j=i;</b></p><p><b>  if(

105、j==-1)</b></p><p>  printf("Not find!Please input again!\n"); //沒有找到該職工,重新輸入</p><p><b>  }</b></p><p>  while(j==-1);</p><p>  printf("

106、;\n");</p><p><b>  f2();</b></p><p>  output(j); //輸出信息</p><p><b>  }</b></p><p>  if(d!=1&&d!=2)</p><p><b>  

107、{</b></p><p>  printf("\nInput error! Press any key to continue."); //輸入錯誤,按enter鍵繼續(xù)</p><p>  getchar();</p><p>  Search(); //返回到查找函數(shù)</p><p><b>

108、;  }</b></p><p>  select(); //選擇顯示信息或返回到菜單</p><p><b>  }</b></p><p>  void Add() //添加函數(shù)</p><p><b>  {</b></p><p>  int i

109、,k,m,n;</p><p>  FILE *fp; //定義一個文件指針</p><p>  system("cls"); //清屏</p><p><b>  n=P();</b></p><p>  printf("\n\nHow many people do you wan

110、t to add:"); //輸入需要添加的職工人數(shù)</p><p>  scanf("%d",&m);</p><p><b>  k=m+n;</b></p><p>  if(k<=100)</p><p><b>  {</b></p&g

111、t;<p>  printf("\n\nPlease input their information:\n\n"); //輸入添加的職工信息</p><p><b>  f1();</b></p><p>  for(i=n;i<k;i++)</p><p><b>  {</b>

112、</p><p><b>  input(i);</b></p><p>  worker[i].sum=worker[i].jibengongzi+worker[i].zhiwugongzi+worker[i].jintie</p><p>  -worker[i].yiliaobaoxian-worker[i].gongjijin; //

113、職工的總工資</p><p><b>  }</b></p><p>  if((fp=fopen("D:\\zggz.txt","ab"))==NULL) //如果文件為空,則不能打開文件</p><p><b>  {</b></p><p>  pri

114、ntf("\nCan not open file.\n"); //不能打開文件</p><p>  getchar();</p><p>  menu(); //返回到菜單</p><p><b>  }</b></p><p>  for(i=n;i<k;i++)</p>

115、<p>  if(fwrite(&worker[i],sizeof(struct worker),1,fp)!=1) //判斷是否寫入了數(shù)</p><p>  printf("file write error.\n"); //文件寫入錯誤</p><p>  fclose(fp); //關閉文件</p><p>  

116、select(); //選擇顯示信息或返回到菜單</p><p><b>  }</b></p><p><b>  else</b></p><p>  Add(); //返回到添加函數(shù)</p><p><b>  }</b></p><p&g

117、t;  void Delete() //刪除函數(shù)</p><p><b>  {</b></p><p>  int i,j=-1,d,k,t,n;char m[20];</p><p>  FILE *fp; //定義一個文件指針</p><p>  system("cls"); //

118、清屏</p><p><b>  n=P();</b></p><p>  fp=fopen("D:\\zggz.txt","rb"); //打開只讀文件</p><p>  printf("\n\n");</p><p>  printf("Cho

119、ose the way you want to delete:\n"); //選擇通過何種方式刪除信息</p><p>  printf("\n\n"); //刪除函數(shù)的界面</p><p>  printf("\t\t****************************************\n");</p>

120、<p>  printf("\t\t* *\n");</p><p>  printf("\t\t* 1.By name to delete *\n");</p><p>  printf("\t\t*

121、 *\n");</p><p>  printf("\t\t* 2.By number to delete *\n");</p><p>  printf("\t\t* *\n&quo

122、t;);</p><p>  printf("\t\t****************************************\n");</p><p>  printf("\ninput your selection:"); //選擇刪除的方式</p><p>  scanf("%d",&

123、;d);</p><p>  if(d!=1&&d!=2)</p><p><b>  {</b></p><p>  printf("\ninput error! Press any key to continue."); //輸入錯誤,按enter鍵繼續(xù)</p><p>  ge

124、tchar();</p><p>  Delete(); //返回到刪除函數(shù)</p><p><b>  }</b></p><p>  else if(d==1)</p><p><b>  {</b></p><p><b>  do</b>&l

125、t;/p><p><b>  {</b></p><p>  printf("\nPlease input the name:"); //輸入需要刪除的職工姓名</p><p>  scanf("%s",m);</p><p>  for(i=0;i<n;i++)</p&

126、gt;<p>  if(strcmp(m,worker[i].name)==0)</p><p><b>  j=i;</b></p><p><b>  if(j==-1)</b></p><p>  printf("\nNot find!Please again!\n"); //沒有

127、找到該職工,重新輸入</p><p><b>  }</b></p><p>  while(j==-1);</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b>

128、;</p><p><b>  do</b></p><p><b>  {</b></p><p>  printf("\nPlease input the num:"); //輸入需要刪除的職工工號</p><p>  scanf("%d",&

129、k);</p><p>  for(i=0;i<n;i++)</p><p>  if(k==worker[i].num)</p><p><b>  j=i;</b></p><p><b>  if(j==-1)</b></p><p>  printf("

130、;\nNot find!Please again!\n"); //沒有找到該職工,重新輸入</p><p><b>  }</b></p><p>  while(j==-1);</p><p><b>  }</b></p><p>  printf("\n");&

131、lt;/p><p><b>  f2();</b></p><p>  for(i=j;i<n-1;i++)</p><p>  worker[i]=worker[i+1]; //刪除信息后,將后面的職工信息按原來的順序補充</p><p>  for(i=0;i<n-1;i++)</p>&l

132、t;p>  output(i);</p><p>  printf("Save it?\n\n1.Yes 2.No\n"); //詢問是否保存刪除后的職工信息</p><p>  scanf("%d",&i);</p><p><b>  if(i==1)</b></p>&

133、lt;p>  save(n-1); //保存刪除后的職工信息</p><p>  printf("\nPress any key to back!"); //按enter鍵繼續(xù)</p><p>  getchar();</p><p>  menu(); //返回到菜單</p><p><b>  

134、}</b></p><p>  void Show() //顯示函數(shù)</p><p><b>  {</b></p><p>  int i,p,a=0,b=0,c=0,j=0,k=0,l=0,m=0,n=0;</p><p><b>  p=P();</b></p>

135、<p>  system("cls"); //清屏</p><p><b>  f2();</b></p><p>  for(i=0;i<p;i++)</p><p>  output(i);</p><p>  printf("\nnaverage salary:\n&

136、quot;);</p><p>  for(i=0;i<p;i++) //各項工資的總和</p><p><b>  {</b></p><p>  j+=worker[i].jibengongzi;</p><p>  k+=worker[i].zhiwugongzi;</p><p&g

137、t;  l+=worker[i].jintie;</p><p>  m+=worker[i].yiliaobaoxian;</p><p>  n+=worker[i].gongjijin;</p><p><b>  }</b></p><p>  printf("%13d %11d %12d %7d %1

138、5d",j/p,k/p,l/p,m/p,n/p);</p><p>  printf("\n(qian san xiang)renshu baifenbi\n");</p><p>  for(i=0;i<p;i++) //統(tǒng)計前三項工資在各個范圍內(nèi)的人數(shù)</p><p><b>  {</b></p

139、><p>  if(worker[i].qiansan>3000)</p><p><b>  a++;</b></p><p>  else if(worker[i].qiansan>=2000 && worker[i].qiansan<=3000)</p><p><b>  

140、b++;</b></p><p>  else if(worker[i].qiansan>=1000 && worker[i].qiansan<=2000)</p><p><b>  c++;</b></p><p><b>  }</b></p><p>

141、  //顯示前三項工資在各個范圍內(nèi)的人數(shù)及所占人數(shù)的百分比</p><p>  printf(" over 3000:%-7d%6d%%\n",a,(a*100/p)); </p><p>  printf(" 2000~3000:%-7d%6d%%\n",b,(b*100/p));</p><p>  

142、printf(" 1000~2000:%-7d%6d%%\n",c,(c*100/p));</p><p>  printf("\n");</p><p>  printf("Press any key to back.");</p><p>  getchar();</p><

143、;p>  menu(); //返回到菜單</p><p><b>  }</b></p><p>  void Exit() //退出函數(shù)</p><p><b>  {</b></p><p>  int i,p,a=0,b=0,c=0,j=0,k=0,l=0,m=0,n=0;<

144、;/p><p><b>  p=P();</b></p><p>  system("cls"); //清屏</p><p><b>  f2();</b></p><p>  for(i=0;i<p;i++)</p><p>  output(i)

145、;</p><p>  printf("\nnaverage salary:\n");</p><p>  for(i=0;i<p;i++) //各項工資的總和</p><p><b>  {</b></p><p>  j+=worker[i].jibengongzi;</p>

溫馨提示

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

評論

0/150

提交評論