数据结构教务处管理系统

 2025-01-19 08:33:01  阅读 152  评论 0

摘要:好像没有数据结构的 你试试c++语言面向对象程序设计课程设计这个网站能免费下几个,不能免费下的就要收费了本站免费计算机课程设计论文下载本人原创计算机类课程设计免费下载,销售计算机毕业论文请把我的网站介绍给同学们.谢谢支持本站ACCESS课程设计库存管理工资管理系统 s

好像没有数据结构的 你试试c++语言面向对象程序设计课程设计

这个网站能免费下几个,不能免费下的就要收费了

本站免费计算机课程设计论文下载

数据结构教务处管理系统

本人原创计算机类课程设计免费下载,销售计算机毕业论文

请把我的网站介绍给同学们.谢谢支持本站

ACCESS课程设计库存管理工资管理系统 sqlserver数据库课程设计 c++语言面向对象程序设计课程设计 vb课程设计学生成绩系统

asp留言板(没有论文) 计算机实训计算机组装与维护课程设计

简单的网页设计没有论文 office课程设计 操作系统课程设计

另有以上没有列出的计算机课程设计为收费材料30元一份 更多

数据结构 程序设计 用双向循环链表建立一个学生管理系统,要求实现插入,删除,排序,修改等功能。

一、需求分析

1. 系统菜单的主要功能

(1)输入若干条记录

(2)查找并修改记录

(3)查找并删除记录

(4)成绩排序

(5)查找并显示一条记录

(6)将数据载入内存中

(7)将所有数据写入文件中

(0)退出程序

2. 功能分析

功能1为输入一条记录到结构体中去。

功能2、3和5算法相似,都是先查找成绩,2、3在此基础上再对查找出的信息进行操作。因为学生姓名定义成了字符数组的形式,因此在运用选择法进行排序的时候,要用到strcmp,strcpy等函数

功能4为成绩排序,可按学生学号排序或某单科成绩或总分排序,并输出相关的学生信息等。

功能6和7是对文件的操作,提前准备好数据。

二、总体设计

“学生成绩管理系统”包括:成绩录入、修改、删除、成绩统计和信息保存、载入这几个模块。

1、 主函数 main()

利用无限次循环while(1)和swithch()实现各函数的调用,系统根据输入的数字选项来调用相应的函数。

2、 菜单选择函数showmenu ()

这是一个无参函数,主要实现“功能选择”的界面,在这个界面里有显示系统的各项功能选单,根据每个功能前面的序号进行选择。等执行完每一个函数功能后,按任一键回到主界面也要通过这个函数来实现!3、 输入记录函数addstudent (stu *s)这是一个带参函数,用来执行第学生成绩记录的输入,当学生为0时停止输入。

算法:利用函数参数s,并将s->next设为NULL。每输入一个数据就声明一个新节点p,把p->next设为NULL,并且链接到之前列表的尾端。

4、 显示记录函数showstudent (stu *s)这是一个不返回值的有参函数,形参为“链表头的指针”,负责对全部学生成绩记录的输出,不足之处就是不能对学生成绩进行分页显示。算法:先将p结点的指针指向第一个结点,将p结点(即第一个结点)的数据输出。然后再将p结点的指针指向p指针的的指针(即下一结点),将p结点(即第一结点)的数据输出。重复执行此步聚直到p指针指向NULL为止。

5、 查找记录函数findstudent (stu *s)这是一个不返回值的有参函数,形参为“链表头的指针”,实现按学号对某个学生进行查找,并显示所查找到的记录。算法:采用线性查找法往下一个节点查找。输入所要查找的学生的学号s,设一个指针变量p,先指向第一个结点,当strcmp(p->name,s) &&p != NULL时,使p后移一个结点,如果p!=NULL,输出p所指的结点。

6、 删除记录函数delstudent (stu *s)这是一个有参函数,形参为“链表头的指针”,先输入要删除的学生记录的学号,找到后显示该学生信息,等确认后便可按“Y”进行删除。算法:从p指向的第一个结点开始,检查该结点中的num值是否等于输入的要求删除的那个学号。如果相等就将该结点删除,如不相等,就将p后移一个结点,再如此进行下去,直到遇到表尾为止。

7、保存数据到文件函数savestudent (stu *s)这是一个不返回值的有参函数,形参为“链表头的指针”,可以把学生记录保存在电脑上由自己任意命名的二进制文件。

8、从文件读数据函数loadstudent (stu *s)这是一个不返回值的有参函数,形参为“链表头的指针”,根据输入的文件地址进行读取。

三、程序流程图

1)成绩统计:

2)信息录入:

3)信息修改:

4)信息删除:

4)信息查询:

4)信息保存:5)主函数:

四、程序调试及体会

1)程序演示:

2)程序调试:

(1)刚开始没有那个初始化函数,程序运行后,没有输入任何数据就试得去执行显示功能,结果显示的是一些乱码!加入初始化函数后,这种现象也随之消失。

(2)刚开始执行输入函数,按学号顺序输入十个学生的成绩,输完后执行显示功能,学生成绩记录是按学号的反顺序显示的,试着在其中增加一些语句,希望能把学号按正常顺序显示,但暂时没有成功,所以在输入成绩时只能按学号反顺序输入,最后就按学号正常顺序输出了。

(3)刚开始时,先把成绩按平均分排序,再插入一个学生的成绩,执行显示功能,虽然插入的学生的成绩能正常插入,但该学生的名次为0。后来,在插入成绩之后,调用排序函数,把所有成绩重新排序一次。

(4)在输入函数中设了一个无限循环,可以输入无数个学生的成绩信息,当学号为0的时候则停止输入。

(5)输入太多个学生的成绩时,屏幕显示不能控制为一页一页显示,所以为了方便起见,不要输入太多记录,十七左右为最佳。

(6)在没有输入任何信息的情况下,去执行排序功能,最后显示有一个记录,学号、姓名为空白,成绩都为0,名次为1。

(7)在输入选项时不能输入字母,否则会死循环,建议不要乱输字母。

3)心得体会:

经过一个星期的课程设计,感觉自己收获不少!

首先是:链表是数据结构的基本体现,所以这个课程设计里面主要都是用链表,而已要达到这样的功能,使用链表相当方便,但不容易理解,所以在这方面我很了很多的时间看课本和参考课外书,使C语言的知识强化了不少。

其次,在做课程设计的过程中,发现了平时很多没有注意到的问题,例如:返回值函数和不返回值函数两者在主函数中的调用是不同的…………

更重要的是,这次课程设计虽然花了我不少时间,但正是这些时间,让我见识到了要学好C语言,数据的处理是相当重要的。这个学生成绩管理系统都是在自己知识范围内完成的,所以界面清晰简单,可能不是很好看,但绝对实用!

从这里我也得到一个体会,做一个程序,或者开发一个软件,应该着重从它的后台制作入手,不能做出一个中看不中用的程序或者软件。

相信这次的课程设计为我以后继续从事计算机工作打了一个小小的开头。

参考书目;

[1]谭浩强. C程序设计(第三版) . 北京:清华大学出版社, 2006

[2]谭浩强. C程序设计上机指导(第三版) . 北京:清华大学出版社, 2005

[3]严蔚敏、吴伟民. 数据结构(C语言版) . 北京:清华大学出版社, 2006

计算机科学与技术系课程设计评分表

用一下我的吧

是我大一时写的

有什么问题可以追问

#include<iostream.h>

#include<string.h>

typedef struct

{

char name[10]

long num

float score

}student

void creat(student stu[])

void insert(student stu[])

void Delete(student stu[])

void lookup(student stu[])

void update(student stu[])

void stat(student stu[])

int length(student stu[])

void print(student stu[])

void creat(student stu[])

{

cout<<"请输入学生人数:"

int n

cin>>n

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<endl

for(int i=1i<=ni++)

{

char newname[10]

long newnum

float newscore

cin>>newname

strcpy(stu[i].name,newname)

cin>>newnum

stu[i].num=newnum

cin>>newscore

stu[i].score=newscore

}

strcpy(stu[i].name," ")

stu[i].num=0

stu[i].score=0

}

void print(student stu[])

{

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<'n'

int i=1

while(i<=length(stu))

{

cout<<stu[i].name<<'t'<<stu[i].num<<'t'<<stu[i].score<<'n'

i++

}

cout<<'n'

}

void lookup(student stu[])

{

cout<<"请输入你要查询的学号:"

long num

cin>>num

int i=1

while(stu[i].num)

{

if(stu[i].num==num)

{

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<'n'

cout<<stu[i].name<<'t'<<stu[i].num<<'t'<<stu[i].score<<'n'

break

}

i++

}

if(!stu[i].num)

{

cout<<"你要查询的学号不存在,请重新输入!"<<'n'

lookup(stu)

}

cout<<'n'

}

void insert(student stu[])

{

if(length(stu)==100)

{

cout<<"存储空间已满,不能进行插入操作!"<<'n'

}

else

{

cout<<"请输入要插入的位置:"

int m

cin>>m

int n=length(stu)

if(m>n+1)

{

cout<<"插入位置不正确,请重新插入!"<<'n'

insert(stu)

}

else

{

for(int i=n+1i>=mi--)

{

strcpy(stu[i+1].name,stu[i].name)

stu[i+1].num=stu[i].num

stu[i+1].score=stu[i].score

}

cout<<"请依次输入姓名,学号,成绩"<<'n'

char newname[10]

long newnum

float newscore

cin>>newname

strcpy(stu[m].name,newname)

cin>>newnum

stu[m].num=newnum

cin>>newscore

stu[m].score=newscore

}

}

}

int length(student stu[])

{

int i=1

while(stu[i].num)

{

i++

}

return (i-1)

}

void Delete(student stu[])

{

cout<<"请输入你要删除的学号:"

long num

cin>>num

int i=1

while(stu[i].num)

{

if(stu[i].num==num)

{

int n=length(stu)

for(int j=ij<nj++)

{

strcpy(stu[i].name,stu[i+1].name)

stu[i].num=stu[i+1].num

stu[i].score=stu[i+1].score

}

strcpy(stu[j].name," ")

stu[j].num=0

stu[j].score=0

break

}

i++

}

if(!stu[i].num)

{

cout<<"你要删除的学号不存在,请重新输入!"<<'n'

Delete(stu)

}

}

void stat(student stu[])

{

cout<<"不及格的学生是:"<<'n'

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<'n'

int i=1

while(stu[i].num)

{

if(stu[i].score<60)

{

cout<<stu[i].name<<'t'<<stu[i].num<<'t'<<stu[i].score<<'n'

}

i++

}

cout<<'n'

cout<<"成绩为‘良’的学生是:"<<'n'

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<'n'

i=1

while(stu[i].num)

{

if(stu[i].score>=60 &&stu[i].score<75)

{

cout<<stu[i].name<<'t'<<stu[i].num<<'t'<<stu[i].score<<'n'

}

i++

}

cout<<'n'

cout<<"成绩为‘中’的学生是:"<<'n'

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<'n'

i=1

while(stu[i].num)

{

if(stu[i].score>=75 &&stu[i].score<90)

{

cout<<stu[i].name<<'t'<<stu[i].num<<'t'<<stu[i].score<<'n'

}

i++

}

cout<<'n'

cout<<"成绩为‘优’的学生是:"<<'n'

cout<<"姓名"<<'t'<<"学号"<<'t'<<"成绩"<<'n'

i=1

while(stu[i].num)

{

if(stu[i].score>=90)

{

cout<<stu[i].name<<'t'<<stu[i].num<<'t'<<stu[i].score<<'n'

}

i++

}

cout<<'n'

}

void update(student stu[])

{

cout<<"请输入要修改的位置:"

int m

cin>>m

if(m>length(stu))

{

cout<<"你要修改的位置不存在,请重新输入!"<<'n'

update(stu)

}

else

{

cout<<"请依次输入更改后的姓名,学号,成绩"<<'n'

char newname[10]

long newnum

float newscore

cin>>newname

strcpy(stu[m].name,newname)

cin>>newnum

stu[m].num=newnum

cin>>newscore

stu[m].score=newscore

}

}

void main()

{

cout<<"首先建立学生管理系统!"<<'n'

student stu[101]

creat(stu)

print(stu)

cout<<"len:"<<length(stu)<<endl

int j=100

cout<<"请选择您要进行的操作(1为插入,2为删除,3为查找,4为修改,5为统计,0为取消操作)"

while(j)

{

cout<<"请您选择要进行的操作:"

cin>>j

switch(j)

{

case 1:

{

insert(stu)

print(stu)

break

}

case 2:

{

Delete(stu)

print(stu)

break

}

case 3:

{

lookup(stu)

break

}

case 4:

{

update(stu)

print(stu)

break

}

case 5:

{

stat(stu)

break

}

default:

break

}

}

cout<<"线性表中共有"<<length(stu)<<"个学生"

}

以上就是关于数据结构课程设计-学生成绩管理系统的设计全部的内容,如果了解更多相关内容,可以关注,你们的支持是我们更新的动力!

版权声明:我们致力于保护作者版权,注重分享,被刊用文章【数据结构教务处管理系统】因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!;

原文链接:https://www.yxiso.com/zhishi/1046677.html

发表评论:

关于我们
院校搜的目标不仅是为用户提供数据和信息,更是成为每一位学子梦想实现的桥梁。我们相信,通过准确的信息与专业的指导,每一位学子都能找到属于自己的教育之路,迈向成功的未来。助力每一个梦想,实现更美好的未来!
联系方式
电话:
地址:广东省中山市
Email:beimuxi@protonmail.com

Copyright © 2022 院校搜 Inc. 保留所有权利。 Powered by BEIMUCMS 3.0.3

页面耗时0.0359秒, 内存占用2.01 MB, 访问数据库22次

陕ICP备14005772号-15