数据结构第二周程序的多文件管理
来源:互联网 发布:sql cast函数 编辑:程序博客网 时间:2024/06/04 00:24
- /*
- 烟台大学计算机学院
- 文件名称:f1.cpp,f2.cpp,f.h
- 作者:于琛
- 完成日期:2017年9月7日
- 问题描述:多文件组织(如何将一个文件的代码多文件组织)
- */
- f1.cpp:
- #include <stdio.h>
- #include "f.h"
- double studavg(struct stud2 s2[],int m,int i) //求学号为i的学生的平均分
- {
- int j,n=0; //n为学号为i的学生选学课程数
- double sum=0; //学号为i的学生总分
- for (j=0; j<m; j++)
- if (s2[j].no==i) //学号为i时统计
- {
- n++;
- sum+=s2[j].deg;
- }
- return(sum/n);
- }
- double couravg(struct stud2 s2[],int m,int i) //求编号为i的课程的平均分
- {
- int j,n=0; //n为编号为i的课程选修人数
- double sum=0; //编号为i的课程总分
- for (j=0; j<m; j++)
- {
- if (s2[j].cno==i) //课程编号为i时统计
- {
- n++;
- sum+=s2[j].deg;
- }
- }
- return(sum/n);
- }
- void allavg(struct stud1 s1[],int n,struct stud2 s2[],int m) //求学生平均分和课程平均分
- {
- int i,j;
- printf("学生平均分:\n");
- printf(" 学号 姓名 平均分\n");
- i=0;
- while (i<n)
- {
- j=s1[i].no;
- printf("%4d %10s %g\n",s1[i].no,s1[i].name,studavg(s2,m,j));
- i++;
- }
- printf("课程平均分:\n");
- for (i=1; i<=6; i++)
- printf(" 课程%d:%g\n",i,couravg(s2,m,i));
- }
- f2.cpp:
- #include <stdio.h>
- #include "f.h"
- int main()
- {
- int n=7; //学生记录人数
- int m=21; //学生成绩记录数
- struct stud1 s1[MaxStud]=
- {
- {1,"张斌",9901},
- {8,"刘丽",9902},
- {34,"李英",9901},
- {20,"陈华",9902},
- {12,"王奇",9901},
- {26,"董强",9902},
- {5,"王萍",9901}
- };
- struct stud2 s2[MaxCour]= //规定课程的编号从1到6,同一学生成绩记录连续存放
- {
- {1,1,67},
- {1,2,98},
- {1,4,65},
- {8,1,98},
- {8,3,90},
- {8,6,67},
- {34,2,56},
- {34,4,65},
- {34,6,77},
- {20,1,68},
- {20,2,92},
- {20,3,64},
- {12,4,76},
- {12,5,75},
- {12,6,78},
- {26,1,67},
- {26,5,78},
- {26,6,62},
- {5,1,94},
- {5,2,92},
- {5,6,89}
- };
- allavg(s1,n,s2,m);
- return 0;
- }
- f.h:
- #include <stdio.h>
- #define MaxStud 50 //学生人数最多为50
- #define MaxCour 300 //学生成绩记录数最多为50*6
- struct stud1
- {
- int no; //学号
- char name[10]; //姓名
- int bno; //班号
- };
- struct stud2
- {
- int no; //学号
- int cno; //课程编号
- int deg; //分数
- };
- double studavg(struct stud2 s2[],int m,int i);
- double couravg(struct stud2 s2[],int m,int i);
- void allavg(struct stud1 s1[],int n,struct stud2 s2[],int m);
阅读全文
0 0
- 数据结构第二周程序的多文件管理
- 数据结构第二周项目2--程序的多文件组织
- 数据结构第二周项目--程序的多文件组织
- 数据结构第二周项目-程序的多文件组织
- 数据结构 第二周(3)程序的多文件组织
- 第二周 项目二 程序的多文件
- 第二周项目2程序的多文件组成
- 第二周【项目2程序的多文件组成 】
- 第二周项目2-多文件程序的组织
- 数据结构上机实践第二周项目2- 程序的多文件组织
- 数据结构上机实践第二周项目2- 程序的多文件组织
- 第二周项目三多文件程序
- 第2周项目2 程序的多文件管理
- 第二周项目2程序的多文件组成
- 第二周 项目2 程序的多文件组成 (c++)
- 第二周项目1-多文件程序的组织(课程主页版)
- 关于文件管理系统的数据结构模拟
- 关于文件管理系统的数据结构模拟
- JZOJ5358. 【NOIP2017提高A组模拟9.12】BBQ
- 算法提高 ADV-146 计算器
- Ubuntu(Linux) 下 unzip 命令使用详解
- libevent源码剖析
- QML之按键翻转效果
- 数据结构第二周程序的多文件管理
- 117. Populating Next Right Pointers in Each Node II
- PreferenceFragment
- centos 6.5 yum安装mysql5.6
- c++简单线程池实现
- 初识Ubuntu
- Django admin 页面中文名称加 s 去除 s 设置
- 1081: n个数求和 (多实例测试)
- HGDB更改参数确认是否需要重启