第二周项目二-多文件组织(如何将一个文件的代码多文件组织)

来源:互联网 发布:女生一身淘宝爆款low 编辑:程序博客网 时间:2024/05/28 06:06
  1. /*  
  2. 烟台大学计算机学院  
  3.   
  4. 文件名称:f1.cpp,f2.cpp,f.h  
  5.   
  6. 作者:任泽西
  7.   
  8. 完成日期:2017年9月14日  
  9.   
  10. 问题描述:多文件组织(如何将一个文件的代码多文件组织) 
  11.   
  12. */   
  13.   
  14.   
  15.   
  16. f1.cpp:  
  17.   
  18. #include <stdio.h>  
  19.   
  20.   
  21. #include "f.h"  
  22.   
  23.   
  24.   
  25.   
  26. double studavg(struct stud2 s2[],int m,int i)   //求学号为i的学生的平均分  
  27. {  
  28.     int j,n=0;              //n为学号为i的学生选学课程数  
  29.     double sum=0;           //学号为i的学生总分  
  30.     for (j=0; j<m; j++)  
  31.         if (s2[j].no==i)    //学号为i时统计  
  32.         {  
  33.             n++;  
  34.             sum+=s2[j].deg;  
  35.         }  
  36.     return(sum/n);  
  37. }  
  38. double couravg(struct stud2 s2[],int m,int i)   //求编号为i的课程的平均分  
  39. {  
  40.     int j,n=0;              //n为编号为i的课程选修人数  
  41.     double sum=0;           //编号为i的课程总分  
  42.     for (j=0; j<m; j++)  
  43.     {  
  44.         if (s2[j].cno==i)   //课程编号为i时统计  
  45.         {  
  46.             n++;  
  47.             sum+=s2[j].deg;  
  48.         }  
  49.     }  
  50.     return(sum/n);  
  51. }  
  52. void allavg(struct stud1 s1[],int n,struct stud2 s2[],int m)    //求学生平均分和课程平均分  
  53. {  
  54.     int i,j;  
  55.     printf("学生平均分:\n");  
  56.     printf("  学号     姓名 平均分\n");  
  57.     i=0;  
  58.     while (i<n)  
  59.     {  
  60.         j=s1[i].no;  
  61.         printf("%4d %10s %g\n",s1[i].no,s1[i].name,studavg(s2,m,j));  
  62.         i++;  
  63.     }  
  64.     printf("课程平均分:\n");  
  65.     for (i=1; i<=6; i++)  
  66.         printf(" 课程%d:%g\n",i,couravg(s2,m,i));  
  67. }  
  68.   
  69.   
  70.   
  71. f2.cpp:  
  72.   
  73. #include <stdio.h>  
  74. #include "f.h"  
  75.   
  76. int main()  
  77. {  
  78.     int n=7;        //学生记录人数  
  79.     int m=21;       //学生成绩记录数  
  80.     struct stud1 s1[MaxStud]=  
  81.     {  
  82.         {1,"张斌",9901},  
  83.         {8,"刘丽",9902},  
  84.         {34,"李英",9901},  
  85.         {20,"陈华",9902},  
  86.         {12,"王奇",9901},  
  87.         {26,"董强",9902},  
  88.         {5,"王萍",9901}  
  89.     };  
  90.     struct stud2 s2[MaxCour]=   //规定课程的编号从1到6,同一学生成绩记录连续存放  
  91.     {  
  92.         {1,1,67},  
  93.         {1,2,98},  
  94.         {1,4,65},  
  95.         {8,1,98},  
  96.         {8,3,90},  
  97.         {8,6,67},  
  98.         {34,2,56},  
  99.         {34,4,65},  
  100.         {34,6,77},  
  101.         {20,1,68},  
  102.         {20,2,92},  
  103.         {20,3,64},  
  104.         {12,4,76},  
  105.         {12,5,75},  
  106.         {12,6,78},  
  107.         {26,1,67},  
  108.         {26,5,78},  
  109.         {26,6,62},  
  110.         {5,1,94},  
  111.         {5,2,92},  
  112.         {5,6,89}  
  113.     };  
  114.     allavg(s1,n,s2,m);  
  115.     return 0;  
  116. }  
  117.   
  118.   
  119. f.h:  
  120.   
  121. #include <stdio.h>  
  122. #define MaxStud 50      //学生人数最多为50  
  123. #define MaxCour 300     //学生成绩记录数最多为50*6  
  124.   
  125.   
  126.   
  127. struct stud1  
  128. {  
  129.     int no;         //学号  
  130.     char name[10];  //姓名  
  131.     int bno;        //班号  
  132. };  
  133. struct stud2  
  134. {  
  135.     int no;         //学号  
  136.     int cno;        //课程编号  
  137.     int deg;        //分数  
  138. };  
  139.   
  140. double studavg(struct stud2 s2[],int m,int i);  
  141.   
  142.   
  143. double couravg(struct stud2 s2[],int m,int i);  
  144.   
  145. void allavg(struct stud1 s1[],int n,struct stud2 s2[],int m);  

运行结果:


知识点总结:
学会了分文件的设计思想,学会了如何将整块代码份文件储存,使得以后的程序设计更加方便,更加明了。
学习心得:
学习分文件之后,可以更高效的编写程序。

原创粉丝点击