教师信息管理系统(C语言课程设计)

上传人:vip****66 文档编号:144494181 上传时间:2020-09-09 格式:DOC 页数:40 大小:771.06KB
返回 下载 相关 举报
教师信息管理系统(C语言课程设计)_第1页
第1页 / 共40页
教师信息管理系统(C语言课程设计)_第2页
第2页 / 共40页
教师信息管理系统(C语言课程设计)_第3页
第3页 / 共40页
教师信息管理系统(C语言课程设计)_第4页
第4页 / 共40页
教师信息管理系统(C语言课程设计)_第5页
第5页 / 共40页
亲,该文档总共40页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《教师信息管理系统(C语言课程设计)》由会员分享,可在线阅读,更多相关《教师信息管理系统(C语言课程设计)(40页珍藏版)》请在金锄头文库上搜索。

1、 课程设计任务书 计算机科学与技术 专业 年级 班 一、 设计题目教师信息管理系统设计二、 主要内容 教师信息包括教师号、姓名、性别、年龄、学历、职称、工资、住址、电话等(教师号不重复)。试设计一教师信息管理系统,使之能提供以下功能:(1)系统以菜单方式工作v(2)教师信息录入功能输入v(3)教师信息删除功能v(4)教师信息浏览功能 输出v(5)查询和排序功能:(至少一种查询方式) 算法vl 按教师号查询l 按职称查询等三、 具体要求 围绕课程设计的目的和意义,基本要求如下: 1、认真阅读C语言课程设计指导书,明确课程设计的目的、意义和要求; 2、快速总结C程序设计语言的精髓,如:函数的概念、

2、函数的设计和函数的调用;3、 快速熟悉Tuber C 或C+的上机环境。能熟练进行高级编辑操作(特别是字块操作);熟悉步进式、断点跟踪的程序调试方法,提高工作效率。 4、根据“课程设计题目”,采用结构化的程序设计思想,确定系统的总体设计方案、确定时间进度。如果是多人共一题,则要首先完成小组内的人员分工及安排,不允许重题现象。 5学习并了解良好的程序设计风格。按质、按量、并按时间完成课程设计的任务。 6提供可运行的课程设计系统,参加上机面试答辩。本次课程设计的重点是:学会设计并编写函数,掌握好各函数之间的调用关系;利用文件操作函数,建立数据库并完成对数据库的各种操作;掌握几种典型算法的应用(如:

3、冒泡法、选择排序法和折半查找法)。同时锻炼学生根据题目进行分析、设计、编码、调试程序和书写必要文档的综合处理能力,从实践中学习并体会程序设计的结构化思想和设计方法。四、 进度安排 依照教学计划,课程设计时间为3周。按照软件工程的思想,软件系统的分析设计至关重要,并要充分重视书写“文档”。避免甚至杜绝“拿到题目就编码”的现象。建议将时间分为三个阶段:第一阶段,根据题目要求,拿出系统的总体设计方案:即构思各程序模块的算法,并画出相应的N-S图,同时编写相应的文档;第二阶段,根据N-S图编写程序代码并单独调试,再将调试通过的各个子模块进行集成调试;第三阶段,归纳文档资料,按要求填写在课程设计说明书上

4、,并参加答辩。三个阶段时间分配的大概比例是: 35:45:20。五、 完成后应上交的材料1课程设计的题目、系统的总功能和各子模块的功能;2题目的设计思想(或算法)简述;3主要程序的框图(要求用N-S图);4源程序代码(要求在关键的位置有注释,从而增加程序的可读性);5课程设计的总结报告,主要包括以下内容:(1)课程设计中遇到的主要问题和解决方法;(2)你的创新和得意之处;(3)设计中存在的不足及改进的设想;(4)本次课程设计的感想和心得体会。 以上完成的源程序及相关文档,填写在课程设计说明书上,要求干净整洁,符合课程设计的要求和规范。六、 总评成绩 指导教师 签名日期 年 月 日 系 主 任

5、审核日期 年 月 日目录1 题目设计思想简述52 程序的NS图72.1总程序的NS图72.2各子函数的NS图72.2.1教师信息录入函数82.2.2教师信息浏览函数82.2.3教师信息删除函数92.2.4教师信息查询函数92.2.5教师信息排序函数103 源程序代码114 程序运行效果图334.1登陆界面334.2菜单栏334.3录入功能344.4浏览功能344.5删除功能354.6查询功能354.7排序功能365 总结报告375.1课程设计中遇到的主要问题和解决方法375.2你的创新和得意之处375.3设计中存在的不足及改进的设想375.4本次课程设计的感想和心得体会38主函数1 题目设计思

6、想简述退 出 系 统教师信息排序的函数浏览教师信息的函数删除教师信息的函数查询教师信息的函数录入教师信息的函数 菜单栏函数识别口令的函数 如上图所示,该教师信息管理系统主要是一个以动态链表的应用为基础来实现对教师信息的录入,查询,删除等功能。定义教师结构体如下:struct teacherlong num;/教师号char name20;/姓名char sex5;/性别int age;/年龄char edu20;/学历char title20;/职称long wage;/工资char addr100; /地址char telep15;/电话struct teacher *next;*head=

7、NULL;主函数只进行口令函数和菜单栏函数的调用,主要工作通过菜单函数实现。口令为123456。菜单栏函数通过用switch语句实现不同功能的选择,不同的功能用不同的子函数实现。录入教师信息通过建立动态单链表来实现。浏览教师信息则通过将链表所有数据顺序输出来实现。查询功能只要从链表头开始不断往下一个结点读取信息跟所要查 找的信息比较,直到读取到的信息跟所要查找的信息相同或链表尾为止,并把此结点的信息输出。删除教师信息的函数是通过查找链表中有该信息的结点后将该结点移出链表,即使该结点前一个结点直接指向该结点后面的结点来达到删除信息的目的。 排序函数是通过交换结点在链表中的位置来实现的,即使得各结

8、点在链表中的位置便是所要得到的排序该信息应在的位置,这样直接顺序输出链表的信息时就能按所要的排序输出了。2 程序的NS图2.1总程序的NS图i=0输入口令a 当i3 当b6 T a=123456? F 假i=i+1退出循环口令3次输入错误 , 退出系统教师信息录入功 能教师信息浏览功 能教师信息删除功 能T b=4? F T b=3? FT b=2? F T b=1? F重新输入所要选择的功能b输入所选择的功能bT i=3? F 教师信息查询功 能T b=5? F 退出系统教师信息排序功 能 说明:各功能都是通过调用子函数来实现的。2.2各子函数的NS图子函数主要包括教师信息录入,教师信息浏览

9、,教师信息删除,教师信息查询和教师信息排序等5个。在退出系统时调用了一个保存信息到文件中的函数,该函数只是简单的应用了文件的读写功能,在此不写出其NS图。2.2.1教师信息录入函数p1=(struct teacher *)malloc(LEN)输入一个教师号p1-numn=n+1n输入教师的姓名,性别,年龄,学历,职称,月薪,住址,电话T 第一个录入? F 当教师号不为0p3=p3-nextHead=p1p3-next=p1 当p3-next不为空p3=headT 链表头为空? FT 教师号为0? Fhead=p1p2-next=p1p2=p1p1=(struct teacher *)mall

10、oc(LEN)输入一个教师号p1-nump2-next=NULL说明:p1=(struct teacher *)malloc(LEN)中LEN是在程序开头的宏定义(#define LEN sizeof(struct teacher)。其中n为全局变量,用来统计链表的结点数,以下出现的n都是同一个。2.2.2教师信息浏览函数p=headT 链表头为空? F 直到p为空输出p所指向的位置中的教师的所有信息显示“还未录入过信息”p=p-next说明:实际程序中在链表头为空是提供了可以浏览之前保存在文件中的信息的功能,当选择该功能时就调用了一个读取文件的函数。该函数只是对文件读写的简单应用,详细请看后面第三部分代码,这里不写出其N-S图。T 链表头为空? F2.2.3教师信息删除的函

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 教育学

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号