第二周项目二

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值