第二周 项目2-程序的多文件组织
2015-09-11 08:27
465 查看
/*
*Copyright(c) 2015, 烟台大学计算机学院
*All rights reserved.
*文件名称:程序的多文件组织.cpp
*作 者:周洁
*完成日期:2015年 9月12 日
*版 本 号:
*
*问题描述:通过这个项目,用多文件组织程序。最简单的多文件组织,一个项目中有三个文件:
.h 头文件:定义数据类型,声明自定义函数,定义宏等。
.cpp 源文件1:用于实现头文件中声明的自定义函数。
.cpp 源文件2:定义main()函数,用于调用相关函数,实现问题求解目标。
请将例1.13中按方案3实现的程序,用多文件形式组织并运行。
在需要的地方,用#include"自定义头文件",使文件之间的内容能“合起来”完成任务。
*输入描述:无
*程序输出:学生信息
*/
(1).h头文件:定义数据类型,声明自定义函数,定义宏
#include<stdio.h>
#define MaxStud 50 //学生最多50人
#define MaxCour 300 //学生的成绩记录最多为50*6
double studavg(struct stud2 s2[],int m,int i); //求学号为i的学生的平均分
double couravg(struct stud2 s2[],int m,int i); //求编号为i的课程的平均分
void allavg(struct stud1 s1[],int n,struct stud2 s2[],int m); //求学生平均分和课程平均分
struct stud1
{
int no; //学号
char name[10]; //姓名
int bno; //班号
};
struct stud2
{
int no; //学号
int cno; //课程编号
int deg; //课程分数
};
(2).cpp 源文件1:用于实现头文件中声明的自定义函数
#include"head.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));
}
(3) .cpp 源文件2:定义main()函数,用于调用相关函数
#include"head.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;
}
运行结果:
![](https://img-blog.csdn.net/20150912092924113?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center)
知识点总结:
主函数调用副函数,程序的多文件组织(放在同一个工程内)
学习心得:
通过自定义的头文件使得编程更加便捷了,但是学的还是不够好,还是不熟练,还好有同学的帮忙。不过,以后会更加努力的。
*Copyright(c) 2015, 烟台大学计算机学院
*All rights reserved.
*文件名称:程序的多文件组织.cpp
*作 者:周洁
*完成日期:2015年 9月12 日
*版 本 号:
*
*问题描述:通过这个项目,用多文件组织程序。最简单的多文件组织,一个项目中有三个文件:
.h 头文件:定义数据类型,声明自定义函数,定义宏等。
.cpp 源文件1:用于实现头文件中声明的自定义函数。
.cpp 源文件2:定义main()函数,用于调用相关函数,实现问题求解目标。
请将例1.13中按方案3实现的程序,用多文件形式组织并运行。
在需要的地方,用#include"自定义头文件",使文件之间的内容能“合起来”完成任务。
*输入描述:无
*程序输出:学生信息
*/
(1).h头文件:定义数据类型,声明自定义函数,定义宏
#include<stdio.h>
#define MaxStud 50 //学生最多50人
#define MaxCour 300 //学生的成绩记录最多为50*6
double studavg(struct stud2 s2[],int m,int i); //求学号为i的学生的平均分
double couravg(struct stud2 s2[],int m,int i); //求编号为i的课程的平均分
void allavg(struct stud1 s1[],int n,struct stud2 s2[],int m); //求学生平均分和课程平均分
struct stud1
{
int no; //学号
char name[10]; //姓名
int bno; //班号
};
struct stud2
{
int no; //学号
int cno; //课程编号
int deg; //课程分数
};
(2).cpp 源文件1:用于实现头文件中声明的自定义函数
#include"head.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));
}
(3) .cpp 源文件2:定义main()函数,用于调用相关函数
#include"head.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;
}
运行结果:
知识点总结:
主函数调用副函数,程序的多文件组织(放在同一个工程内)
学习心得:
通过自定义的头文件使得编程更加便捷了,但是学的还是不够好,还是不熟练,还好有同学的帮忙。不过,以后会更加努力的。
相关文章推荐
- 认证流程【1】-main函数
- RAII惯用法:C++资源管理的利器
- 加班能体现编程工作的热情吗?
- CentOS 7 x64 Codis 群集 以及 单机 docker
- leetcode: (122) Best Time to Buy and Sell Stock II
- JavaWeb第三周-利用JS中正则表达式实现注册的信息验证。
- QT数据传输中的对象序列化与反序列化
- ettercap进行arp欺骗攻击
- 第二周 项目二 程序的多文件组织
- 杭电OJ--2097 Sky数
- 开源免费天气预报接口API以及全国所有地区代码!!(国家气象局提供)
- 第2周项目1 函数参数传递的三种方式
- 第二周实践项目2-程序的多文件组织
- 【读书笔记】iOS-垃圾回收
- IOS学习笔记之获取Plist文件读取数据
- 20150910输入一个日期判断是这一年的第一天
- 【读书笔记】iOS-垃圾回收
- 经方败案群崩漏专题1
- 第二周项目3的程序1——复杂度是O(n 2 )的选择排序程序
- Leetcode: Palindrome Permutation