C语言程序设计实训说明书 某学院教学信息管理系统.docx

上传人:b****2 文档编号:1963156 上传时间:2022-10-25 格式:DOCX 页数:42 大小:3.10MB
下载 相关 举报
C语言程序设计实训说明书 某学院教学信息管理系统.docx_第1页
第1页 / 共42页
C语言程序设计实训说明书 某学院教学信息管理系统.docx_第2页
第2页 / 共42页
C语言程序设计实训说明书 某学院教学信息管理系统.docx_第3页
第3页 / 共42页
C语言程序设计实训说明书 某学院教学信息管理系统.docx_第4页
第4页 / 共42页
C语言程序设计实训说明书 某学院教学信息管理系统.docx_第5页
第5页 / 共42页
点击查看更多>>
下载资源
资源描述

C语言程序设计实训说明书 某学院教学信息管理系统.docx

《C语言程序设计实训说明书 某学院教学信息管理系统.docx》由会员分享,可在线阅读,更多相关《C语言程序设计实训说明书 某学院教学信息管理系统.docx(42页珍藏版)》请在冰豆网上搜索。

C语言程序设计实训说明书 某学院教学信息管理系统.docx

C语言程序设计实训说明书某学院教学信息管理系统

中北大学

程序设计实训

说明书

 

学院、系:

软件学院

专业:

软件工程

学生姓名:

学号:

1314010xxx

设计题目:

某学院教学信息管理系统

起迄日期:

2014年11月21日~2015年1月17日

指导教师:

何志英

 

 

 

 2015年1月10日

 

一、选题要求

题目一:

某学院教学信息管理系统

功能:

1、每一条记录包括一位教师的职工号、姓名、职称、性别、3门主讲课程(课程名称、开课学期、课程性质(学位与非学位课)和教学效果),教学效果综合评分。

2、输入功能:

可以一次完成若干条记录的输入。

3、显示功能:

完成全部教师记录的显示。

4、查找功能:

完成按姓名或课程查找教师的相关记录,并显示。

5、排序功能:

按职工号或教学效果综合评分进行排序。

6、插入功能:

按教学效果综合评分高低插入一条教师记录。

7、将教师记录存在文件中。

8、应提供一个界面来调用各个功能,调用界面和各个功能的操作界面应尽可能清晰美观!

要求:

1、用C语言实现系统;

2、利用结构体数组实现教学信息的数据结构设计;

3、系统具有增加,查询,插入,排序等基本功能;

4、系统的各个功能模块要求用函数的形式实现;

5、将教学信息存在文件中。

考试题目要求:

1、按教师性别统计统计评分的总算

2、删除一个函数,程序仍能正常运行

二、程序设计方法及主要函数介绍

程序设计方法

1.数据结构的设计:

程序要求文档中要求使用结构体数组完成设计,每一条记录包括一位教师的职工号、姓名、职称、性别、3门主讲课程(课程名称、开课学期、课程性质(学位与非学位课)和教学效果),教学效果综合评分。

数据结构设计如下:

typedefstructCourse{//课程的定义与描述

charcourseName[40];//课程名称

intsemester;//开课学期

chartype[8];//课程性质

charteceff;//教学效果

}Course;

typedefstructTeacher{//教师的定义与描述

charname[8];//姓名

intnum;//职工号

charsex[2];//性别

inttecscore;//教学效果综合评分

charposition[8];//职称

Coursecourse[3];//3门主讲课程

}Teacher;

2.主函数与其他函数的关系:

3.结构化的程序设计方法

将实用功能封装在每一个子函数中,主函数通过调用子函数来实现相对应的功能。

体现了“自顶向下,逐步求精”的结构化程序设计思想。

4.“高内聚,低耦合”的程序设计原则

将各个使用功能封装在函数中来让主函数调用,而不是将所有实用功能聚集在主函数中,使得各个模块相对独立,耦合性得以降低,有利于程序的维护。

主要函数介绍:

1.以卡片形式输出全部教师信息

注:

由于版面原因,输出函数显得有些乱,但是这并不影响程序的运行结果,真实的运行结果是很整齐的。

(下图是DevC++V5.5.3版本下的编码界面)

voidPrintInfor(TeacherT[]){//输出全部教师信息(以卡片形式)

printf("--------------------------------------------------------------------------------");

printf("|所有教师记录|");

printf("-------------------------------------------------------------------------------+");

printf("|全院现有在职教师%d名,全部信息如下|",TeacherNum);

printf("-------------------------------------------------------------------------------+\n\n");

for(inti=0;i

printf("+------+---------------+----+------------+----+------+------+------------------+");

printf("|职工号|%3d|姓名|%8s|性别|%s|职称|%8s|",T[i].num,T[i].name,T[i].sex,T[i].position);

printf("+------+---+-----------+----+------------+----+------+------+------------------+");

printf("|主讲课程1|课程名|%-40s|",T[i].course[0].courseName);

printf("+----------+-----------+----------+------------------+------------+------------+");

printf("|学期|%d|课程性质|%8s|教学效果|%c|",T[i].course[0].semester,T[i].course[0].type,T[i].course[0].teceff);

printf("+----------+-----------+----------+------------------+------------+------------+");

printf("|主讲课程2|课程名|%-40s|",T[i].course[1].courseName);

printf("+----------+-----------+----------+------------------+------------+------------+");

printf("|学期|%d|课程性质|%8s|教学效果|%c|",T[i].course[1].semester,T[i].course[1].type,T[i].course[1].teceff);

printf("+----------+-----------+----------+------------------+------------+------------+");

printf("|主讲课程3|课程名|%-40s|",T[i].course[2].courseName);

printf("+----------+-----------+----------+------------------+------------+------------+");

printf("|学期|%d|课程性质|%8s|教学效果|%c|",T[i].course[2].semester,T[i].course[2].type,T[i].course[2].teceff);

printf("+----------+-----+-----+----------+------------------+------------+------------+");

printf("|教学效果综合评分|%3d|",T[i].tecscore);

printf("+----------------+-------------------------------------------------------------+\n\n");

system("PAUSE");//输完一个教师信息,等待用户查看确认,确认无误后再打印下一教师的相关信息

}//for

}//PrintInfor

2.对教师信息排序

voidSort_N(TeacherT[],intn){

//当n=1时按职工号排序,当n=2时按教学效果综合评分排序

if(n==1){//按职工号排序

Teachertemp;

for(inti=0;i

for(intj=0;j

if(T[j+1].num

temp=T[j];

T[j]=T[j+1];

T[j+1]=temp;

}//if

}//for

printf("排序结果如下:

\n");

for(inti=0;i

printf("%8s[%d]",T[i].name,T[i].num);

}//for

printf("\n");

}//if

else{//按教学效果综合评分排序

Teachertemp;

for(inti=0;i

for(intj=0;j

if(T[j+1].tecscore

temp=T[j];

T[j]=T[j+1];

T[j+1]=temp;

}//if

}//for

for(inti=0;i

printf("\t\t\t第%d名:

%-8s分数:

%3d\n",i+1,T[i].name,T[i].tecscore);

}//for

}//else

}//Sort_N

3.按教学效果综合评分高低插入一条教师记录

由于程序要求要按照教学效果综合评分高低进行插入操作,故教师信息必须按一定顺序排列,但是在执行该操作之前不能保证用户已经执行了相应的排序操作,故需要再执行一次排序操作,以保证接下来的程序能够正常运行

插入信息的算法大致描述如下:

在操作之前,教师的教学效果综合评分已经按照从小到大的顺序排列。

先确定插入位置,如需对数据移动则进行移动操作,最后将待插记录复制到插入位置。

插入位置有两种:

A.在所有教师信息之后插入:

当该教师分数大于所有教师的分数时,直接将该教师信息复制在最后一个教师后面的结构体中,无需进行移动,此时的基本操作为数据的复制。

B.在开头或者其他教师之前插入:

当该教师分数满足以下表达式:

min<=tecscore

此时的基本操作是数据的移动与复制(移动的过程本质上也是数据的复制)。

voidInsertInfor(TeacherT[]){

if(TeacherNum==MAXTEACHERNUM){

printf("容量已满,请扩充后再使用!

\n");

return;

}//if

TeacherTB;

//先从键盘接收待插入教师的相关信息,存放于一个临时的结构体变量TB中

printf("->请按要求输入教师信息:

\n");

printf("->请输入教师的职工号(3位数字):

");

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 农林牧渔 > 林学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1