《C语言课程设计报告.doc》由会员分享,可在线阅读,更多相关《C语言课程设计报告.doc(21页珍藏版)》请在金锄头文库上搜索。
1、学生成绩管理系统课程设计报告专 业: 软 件 学 院 班 级: 计HR-06-7班 姓 名: 李 政 源 指导教师: 李 建 中 学 号: 0620010710 课程设计报告一、课程设计题目 基本要求题目:矩阵乘法。 综合训练:学生成绩管理系统二、设计要求矩阵乘法:编写一个函数实现矩阵A(2行3列)与矩阵B 相乘(3行2列),乘积放在C数组中。在主函数中输入相乘的两数组,并输出结果。学生成绩管理:(结构体数组、函数、指针、算法、流程结构及文件等的综合应用)程序说明:有N个学生,每个学生的数据包含学号(不重复)、姓名、三门课的成绩及平均成绩,试设计一学生成绩管理系统,使之能提供以下功能:学生成绩
2、管理系统1、 成绩录入2、 成绩查询3、 成绩统计4、 退出(1)主菜单(2)各菜单项功能 成绩录入:输入学生的学号、姓名及三门课的成绩; 成绩查询:(至少一种查询方式)。v 按学号查询学生记录。v 查询不及格学生的记录。成绩统计:v 计算学生的平均分;v 根据学生的平均分高低,对学生的数据进行排序后输出;v 对学生单科成绩排序,输出学生姓名与该科成绩;退出系统:退出整个系统(即主菜单)。(3)结构体数组:define N 30struct studentint num; /* 定义学号*/ char name20; /* 定义姓名*/float score3; /* 定义存贮三门课成绩的数组
3、*/float average; /* 定义平均成绩*/;struct student stuN; /* 定义结构体数组,存贮多个学生的记录*/三、数据结构设计描述系统功能描述1能够输入学生的学号、姓名、三科成绩并且计算出平均成绩。2能够以表格的形式输出学生记录3能够按照学生三科的平均成绩进行排序4能够按照学生的单科成绩进行排序5能够按照学号查询学生记录6往表中插入学生记录7从表中删除学生记录8存储记录到文件中9从文件中读取记录10退出数据字典1数据流条目数据流名称:全部记录别名:无简述:最新更新后所有关于学生成绩的记录来源:数据库去向:加工“记录筛选”数据流量:不限 组成:学号+姓名+SC1
4、+SC2+SC3+平均成绩数据存储条数据存储名称:学生成绩记录别名:无简述:存放学生所有可供查询的信息组成:学号+姓名+SC1+SC2+SC3+平均成绩组织方式:索引文件,以学学号为关键字查询要求:要求能立即查询2数据项条目数据项名称:学号别名:无简述:所有学校学生的学号类型:字符串3加工条目加工名:更改的记录激发条件:学生成绩记录被改动优先级:普通输入:新记录输出:更新数据、数据未改动加工逻辑:根据现有学生成绩记录if 新记录旧记录then 更新数据else 数据未改动endif设计测试流程1、进入界面 2、输入选项0,回车; 按提示输入数据3、回到主菜单; 输入选项8,回车; 输入文件名:
5、data,回车; 出现成功提示,则读入文件操作成功。4、回到主菜单,输入1,回车 每10个暂停显示数据5、回到主菜单,输入2,回车 出现排序成功信息。6、回到主菜单,输入3,回车 出现排序成功信息。7、回到主菜单,输入5,回车 按提示插入一组数据8、回到主菜单,输入6,回车 按提示输入姓名,删除数据 出现删除成功的信息9、回到主菜单,输入4,回车 输入学号进行查询10、回到主菜单,输入1,回车 出现统计信息11、回到主菜单,输入7,回车输入result,回车出现成功写入文件的信息12、回到主菜单,输入9,回车退出系统四、各变量的定义和作用#define N 3 定义常数 typedef str
6、uct z1 定义数据结构 char no11; char name15; int scoreN; float sum; float average; int order; struct z1 *next; STUDENT;char *menu 定义菜单字符串数组Enter list 输入记录Print list 显示单链表中所有记录 Sort to make new file 按照总成绩排序 sort to Single course result 按照单科成绩排序 Search record on ID 按照学号查找记录 Insert record to list 插入记录到表中 Dele
7、te a record from list 从表中删除记录 Save the file 将单链表中记录保存到文件中Load the file 从文件中读入记录*/ Quit 退出STUDENT *init() 初始化链表STUDENT *create()创建链表,完成数据录入功能inputs(char *prompt, char *s, int count) 自定义输入控制函数inputs五、系统各模块(函数)的组成。功能、参数说明、相互调用关系主函数 main()利用无限次循环for(;)和swithch()实现各函数的调用,系统根据输入的数字选项来调用相应的函数。初始化函数 STUDENT
8、 *init()这是一个无参函数,里面只有一个语句,它的作用是使链表初始化,使head的值为NULL。比如:没有这个函数的话,在你没有输入任何数据的情况下,去执行显示功能的时候会显示一些乱码!菜单选择函数 int menu_select();这是一个无参函数,主要实现“功能选择”的界面,在这个界面里有显示系统的九大功能,根据每个功能前面的序号进行选择,中间还显示系统当前的时间。等执行完每一个函数功能后,按任一键回到主界面也要通过这个函数来实现!输入记录函数 STUDENT *create()这是一个无参函数,用来执行第学生成绩记录的输入,当学生为0时停止输入,函数结束后,带回一个指向链表头的指
9、针head。输入记录函数 STUDENT *create()这是一个无参函数,用来执行第学生成绩记录的输入,当学生为0时停止输入,函数结束后,带回一个指向链表头的指针head。显示记录函数 void print(STUDENT *head)这是一个不返回值的有参函数,形参为“链表头的指针”,负责对全部学生成绩记录的输出,不足之处就是不能对学生成绩进行分页显示。查找记录函数 void search(STUDENT *head)这是一个不返回值的有参函数,形参为“链表头的指针”,实现按学号对某个学生进行查找,并显示所查找到的记录。删除记录函数 STUDENT *delete(STUDENT *he
10、ad)这是一个有参函数,形参为“链表头的指针”,先输入要删除的学生记录的学号,找到后显示该学生信息,等确认后便可按“Y”进行删除。排序函数 STUDENT *sort(STUDENT *head)这是一个有参函数,形参为“链表头的指针”,按学生成绩的平均分高低进行排序,还可以显示名次。插入函数 STUDENT *insert(STUDENT *head,STUDENT *new)这是一个有参函数,形参有两个,一个是“链表头的指针”,一个是“待插入指针”,按照原来成绩平均分的高低进行插入,插入后会重新进行排序,并返回。保存数据到文件函数 void save(STUDENT *head)这是一个不
11、返回值的有参函数,形参为“链表头的指针”,可以把学生记录保存在电脑上由自己任意命名的二进制文件。从文件读数据函数 STUDENT *load()这是一个不返回值的有参函数,形参为“链表头的指针”,根据输入的文件地址进行读取六、各功能模块的算法处理流程图及相关说明1、主函数 main()2、初始化函数 STUDENT *init()3、菜单选择函数 int menu_select();4、输入记录函数 STUDENT *create()算法:先声明一个首节点head,并将head-next设为NULL。每输入一个数据就声明一个新节点p,把p-next设为NULL,并且链接到之前列表的尾端。N-S
12、流程图如下:head=NULLfor(;)指针p指向新开辟的单元指针p是否为空是否输入学号p-num输出p-num是否为0内存是否溢出 输入姓名p-name停止for(i=0;isum=s;菜单 p-average=(float)s/3; p-order=0; p-next=head;head=p;5、 记录函数 void print(STUDENT *head)算法:先将p结点的指针指向第一个结点,将p结点(即第一个结点)的数据输出。然后再将p结点的指针指向p指针的的指针(即下一结点),将p结点(即第一结点)的数据输出。重复执行此步聚直到p指针指向NULL为止。N-S流程图如下: p=hea
13、d,使指向第一个结点 输出p所指向的结点p指向一下个结点当p指的不是表尾6、 找记录函数 void search(STUDENT *head)算法:采用线性查找法往下一个节点查找。输入所要查找的学生的学号s,设一个指针变量p,先指向第一个结点,当strcmp(p-name,s) & p != NULL时,使p后移一个结点,如果p!=NULL,输出p所指的结点。N-S流程图如下:输入要查找的学生的学号sp=head,使p指向第一结点当记录的学号不是要找的,或指针不为空时p=p-next p!=NULL如果指针不为空是否显示没有该输出p所指向的结点学生7、删除记录函数 STUDENT *delet
14、e(STUDENT *head)算法:从p指向的第一个结点开始,检查该结点中的num值是否等于输入的要求删除的那个学号。如果相等就将该结点删除,如不相等,就将p后移一个结点,再如此进行下去,直到遇到表尾为止。N-S流程图如下:p1=head;输入入要删除的学号s当(strcmp(p1-num,s))& p1 != NULLp2=p1 p1=p1-nextp1是要删除的结点是否p1所指是头结点是否输出”找不到”head=p1-nextp2-next=p1-next的信息“(删除头结点)8、排序函数 STUDENT *sort(STUDENT *head)N-S流程图:temp=head-next,head-next=NULL 当tem