顺序表的学生成绩管理系统设计与实现文档格式.docx
- 文档编号:19380025
- 上传时间:2023-01-05
- 格式:DOCX
- 页数:18
- 大小:380.58KB
顺序表的学生成绩管理系统设计与实现文档格式.docx
《顺序表的学生成绩管理系统设计与实现文档格式.docx》由会员分享,可在线阅读,更多相关《顺序表的学生成绩管理系统设计与实现文档格式.docx(18页珍藏版)》请在冰豆网上搜索。
建立一个学生信息管理系统,使学生信息管理工作规范化,系统化,程序化,避免学生管理的随意性,提高信息处理的速度和准确性,能够及时、准确、有效的查询和修改学生信息是必须而且十分迫切的工作。
。
1.1需求分析
学生管理系统功能的信息量大,数据安全性和保密性要求最高。
本功能实现对专业信息、学生信息、教师信息情况信息的管理和统计、课程信息和成绩信息查看及维护。
系统管理员可以浏览、查询、学生的基本信息,能添加、删除和修改学生信息,这部分功能应该由系统管理员执行,但是,删除某条专业基本信息记录时,应实现对该专业的相关信息也级联删除。
并且还应具有查询,并打印输出的功能
1。
2实验目的
1.掌握顺序表的建立.
2.掌握顺序表的基本操作。
3.掌握顺序查找的基本算法
1.3实验内容
利用顺序表实现学生成绩管理系统,具体功能:
输入、输出、插入、除、查找、修改、退出,并能在屏幕上输出操作前后的结果。
第2章系统总体设计
2。
1基本要求
硬件:
微机和打印机一台各
软件:
VisualC++windows7
2算法设计思想
1)分析程序的功能要求,划分程序功能模块
2)画出系统流程
3)代码的编写,定义数据结构和各个功能子函数
4)程序的功能调试
2.3设计要求
1.写出系统需求分析,并建模。
2.编程实现,界面友好.
3.输出操作前后的结果。
4.提供测试报告
第三章系统详细设计
3.1创建空顺序表并初始化
voidcreatList(sqlist*L)
{inti=0,n;
Elemtype*newbase;
L->
elem=(Elemtype*)malloc(List_INIT_SPACE*(sizeof(Elemtype)));
if(!
L—〉elem)
exit(OVERFLOW);
L—>
length=0;
L-〉listsize=List_INIT_SPACE;
printf(”有几位同学:
\n”);
scanf("
%d"
&
n);
for(i=0;
i〈n;
i++)
{if(L—>
length==L->
listsize)
{newbase=(Elemtype*)realloc(L->
elem,(List_INIT_SPACE+List_INC_SPACE)*sizeof(Elemtype));
if(newbase)
{L—>
elem=newbase;
L—>
listsize+=List_INC_SPACE;
}
else
exit(OVERFLOW);
}
printf("
请输入第%d名同学的信息:
\n"
i+1);
printf(”学号(15)\n”);
scanf(”%16s"
L-〉elem[L-〉length].number);
姓名(15)\n”);
%16s”,L—〉elem[L->
length].name);
printf(”性别(男:
M女:
F)\n"
);
scanf(”%16s”,L-〉elem[L—〉length].sex);
成绩\n"
%10d"
,&L-〉elem[L-〉length].score);
L-〉length++;
printf(”%d名学生信息如下:
L-〉length);
学号(15)姓名(15)性别(男:
M女:
F)成绩\n”);
i<
L->
length;
printf(”%—16s%-16s%—16s%—10d\n”,L—>
elem[i].number,L—>
elem[i].name,L->
elem[i].sex,L—〉elem[i]。
score);
}
3。
2向顺序表中插入元素
voidinsertlist(sqlist*L)
{inti,j,k;
charsign=’y’;
Elemtype*newbase;
Elemtypenewelem;
while(sign!
=’n’)
{if(L->
listsize)
{newbase=(Elemtype*)realloc(L—>
elem,(List_INIT_SPACE+List_INC_SPACE)*sizeof(Elemtype));
if(newbase)
{L—>
L—〉listsize+=List_INC_SPACE;
}
elseexit(OVERFLOW);
printf(”请输入要插入的同学的信息:
);
printf(”学号(15)\n"
scanf(”%16s”,newelem.number);
printf("
姓名(15)\n"
scanf(”%16s"
,newelem。
name);
scanf(”%16s"
sex);
printf(”成绩\n"
scanf(”%10d”,&
newelem。
score);
printf(”要插入到第几个位置:
”);
%d”,&i);
while(i<
1||i〉L-〉length+1)
{printf(”不能插入到第%d个位置!
\n只能插入第1到第%d个位置上!
\n请重新输入要插入的位置:
”,L-〉length+1);
scanf("
%d”,&
i);
length++;
for(j=L->
length-1;
j〉i—2;
j-—)
{for(k=0;
k〈16;
k++)
{L->
elem[j]。
name[k]=L—>
elem[j—1]。
name[k];
L—〉elem[j]。
number[k]=L-〉elem[j—1]。
number[k];
L—〉elem[j].sex[k]=L—>
elem[j-1].sex[k];
}
L-〉elem[j].score=L-〉elem[j—1].score;
}
j++;
for(k=0;
k<
16;
{L->
elem[j]。
name[k]=newelem.name[k];
L-〉elem[j].number[k]=newelem.number[k];
L—〉elem[j]。
sex[k]=newelem.sex[k];
score=newelem。
score;
printf(”是否还要输入?
(YorN)”);
getchar();
scanf("
%c"
sign);
if(sign=='
n'
||sign=='
N'
)
sign='
;
}
%d名学生信息如下:
L—>
length);
学号(15)姓名(15)性别(男:
F)成绩\n"
for(i=0;
L—〉length;
i++)
printf(”%-16s%-16s%-16s%-10d\n”,L—〉elem[i]。
number,L—>
elem[i].name,L—〉elem[i]。
sex,L->
elem[i].score);
3查找学生信息
intfindlist(sqlist*L)
{intj;
chari[16];
printf(”1。
按学号查找\n2.按姓名查找\n请选择:
”);
scanf(”%d”,&j);
if(j==1)
{printf("
请输入学号:
"
scanf(”%s”,i);
strcmp(i,L—〉elem[j]。
number))//i==L->
number用数组函数
returnj+1;
return0;
else
请输入姓名:
scanf(”%s"
,i);
for(j=0;
j<
length;
j++)
if(!
strcmp(i,L-〉elem[j]。
name))//用数组函数
returnj+1;
return0;
}}
3.4删除学生信息
intdelnode(sqlist*L)
{intj;
chari[10];
按学号删除\n2。
按姓名删除\n请选择:
scanf(”%d”,&j);
{printf(”请输入学号:
scanf(”%s”,i);
for(j=0;
L—>
j++)
if(!
strcmp(i,L—〉elem[j].number))//i==L-〉elem[j].number用数组函数
{for(;
j〈L—>
L—〉elem[j]=L-〉elem[j+1];
L->
length—-;
return1;
return0;
{printf("
请输入姓名:
%s”,i);
for(j=0;
j〈L-〉length;
if(!
strcmp(i,L->
{for(;
elem[j]=L->
elem[j+1];
//L-〉elem[j]以后的向前挪
length-—;
return0;
}}
3.5输出学生信息
voidprintlist(sqlist*L)
{inti;
printf(”%d名学生信息如下:
\n”,L—>
printf(”学号(15)姓名(15)性别(男:
printf(”%—16s%-16s%—16s%—10d\n”,L-〉elem[i].number,L-〉elem[i]。
name,L-〉elem[i].sex,L-〉elem[i]。
6修改学生信息
voidreviselist(sqlist*L)
{inti,x,a=0;
charname[16];
charsex[16];
charnumber[16];
intscore;
printf(”请选择你要改的同学的姓名”);
scanf(”%16s”,name);
printf(”请选择你要改的同学的信息\n”);
修改学生的姓名\n"
修改学生的学号\n”);
printf(”3.修改学生的性别\n"
4.修改学生的成绩\n”);
scanf(”%d”,&
x);
switch(x)
{case1:
for(i=0;
i〈L->
{if(strcmp(name,L—>
elem[i]。
name)==0)
{printf(”请输入新名字”);
scanf("
%16s”,name);
strcpy(L—>
elem[i]。
name,name);
a=1;
}}
if(a==0)
printf("
对不起你要改的名字不存在\n"
break;
case2:
{if(strcmp(name,L->
elem[i].name)==0)
{printf("
请输入新学号"
scanf(”%16s"
,number);
strcpy(L-〉elem[i].number,number);
a=1;
break;
case3:
{if(strcmp(name,L->
elem[i]。
请输入新性别”);
scanf(”%16s”,sex);
strcpy(L—〉elem[i]。
sex,sex);
}}
if(a==0)
case4:
{if(strcmp(name,L->
{printf(”请输入新成绩"
score);
L—>
score=score;
printf(”对不起你要改的名字不存在\n"
3.7退出学生信息管理系统
voidtuichu(sqlist*L)
{if(!
elem)
free(L-〉elem);
\n\n再见,欢迎下次使用”);
exit(—2);
第四章总体设计
4.1设计概述
根据需求把整个系统分化成不同的模块,每个模块完成一个特定的子功能。
把这些模块结合起来组成一个整体。
逐一实现各个功能。
4。
2系统总流程图及功能模块划分
经过对系统的需求分析,学生信息管理系统主要划分为三个部分:
学生信息查询,学生信息管理,学生成绩录入三个功能模块。
如图4。
2系统的总体结构.
图4。
2系统的总体结构
1学生信息查询模块
学生信息查询:
学生可以根据学号、姓名、专业进行查询。
如图3.2.2学生
信息查询模块结构.
2.1学生信息管理模块结构
4。
2.2学生信息查询模块
如图4.2。
2学生信息查询模块结构。
2
学生信息管理模块结构第5章系统测试
第五章系统测试
1.在调试过程中出现了很多次的程序错误,警告和不能运行.在很多次的
调试和重新改写之后,才可以用。
2.Visual
C++确实是一门需要极其细心和耐心的课程,尤其在程序设计的过
程中不可有一丝的马虎大意,否则将会花很大力气去改正。
调试过程中最常见的便是代码输入错误,如字母大小写、顺序颠倒、符号的半/全角使用等一些问题,都是在调试过程中逐一改正的。
5.1实验结果
1.初始化
输入
3插入
4查找
5删除
6修改
7退出
实验总结
在程序设计方面,逐渐感觉到模块化设计的重要性。
在程序设计时,应该分析出功能块,然后对其细节中的共性和特性作分析。
在算法上使得其结果精简、完整,达到模块化,在编程时,思考方式就会集中在结构的逻辑上而非细节的问题上。
这样可以使得程序更加严密可靠。
而这样的技能是要在每次的程序设计及编程中慢慢积累的。
这次的设计,让我大大地感觉到,对于程序设计中,对语言再熟悉也比不过在设计中算法和结构分析的真知灼见.当然,成功的程序设计是要建立在熟悉语言的基础之上的。
平时语言的基本功要扎实。
而每一次程序设计的经营能大大地增加对语言的熟悉和感知。
程序设计的技能来自多方面,每一次的亲自实践、思考揣摩、刨根问底就会让自己更加清楚所欠缺的是什么。
所以,现在觉得在设计实践中作为参考的书册阅读和研究远远比过单纯的阅读,因为它是在最紧迫的时间上填补自己最紧迫的不足。
收获与心得
通过这次程序设计,增加了我们学习软件的兴趣,加强了小组成员之间的协作能力.
这次程序设计由老师提供课题,参考范例程序,经过自己的改写,实现程序设计要求。
一个模块一个模块去做,在实际操作过程中会有一些错误,我们要自己动手去改,这样不光能学到知识还能有一些体会.在具体操作中,不光能对这学期所学的知识得到巩固,还能发现自己的不足之处,在以后操作中能更加注意.通过实际
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 顺序 学生 成绩管理系统 设计 实现