C语言学生信息管理系统实验报告.docx
《C语言学生信息管理系统实验报告.docx》由会员分享,可在线阅读,更多相关《C语言学生信息管理系统实验报告.docx(37页珍藏版)》请在冰豆网上搜索。
C语言学生信息管理系统实验报告
.
C语言课程设计
学生信息管理系统
姓名洪伟生
院系计算机学院
日期2015年7月5日
教育资料
.
第一章设计要求⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
第二章算法分析
1.理论依据⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
2.主要实现方法⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
2.1整体流程图⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
2.2函数功能和函数之间的调用关系⋯⋯⋯⋯⋯⋯
第三章代码(源代码)⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
第四章分析说明⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
第五章总结⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯⋯
第一章、设计要求
1、利用所学的知识、理论和实际结合,利用资源,采用模块化的结构,使用模仿修改自主设计相结合的方法,锻炼学生综合分析解决实际问题的编程能力;
2、通过C语言各个函数功能来实现对学生信息的管理,学生信息包括学生姓名,学号,
各科成绩;管理方式包括对学生信息的录入,保存,排序,查找、修改、删除等功能。
第二章、算法分析
1、程序理论依据
通过C语言的程序设计基础的掌握,对学生成绩管理系统进行编写程序。
首先,通过链表这一数据结构来对学生的信息进行录入以及操作,在其过程中,通过各个功能语句以及选
择结构,循环结构等方式的结合来达到所要实现的程序功能。
最后通过对C语言中对文件的操作,对已有学生成绩的读取和新建学生成绩的录入保存。
教育资料
.
2、主要实现方法
2.1整体流程图
学生信息管
理系统
进入退出
学
学
学
学
学
学
返
生
生
生
生
生
生
回
信
信
信
信
信
信
主
息
息
息
息
息
息
菜
录
浏
查
修
增
删
单
入
览
找
改
加
除
2.2、函数功能和函数之间的调用关系
2.2.1
、函数功能:
voidMenu_1();
//
主菜单
voidMenu_2();
//
二级菜单
void
swap(struct
student*phead,struct
student*pback);
//
链
表节点互换
voidSave(structstudent*head);
//
写入磁
盘
voidSearch(structstudent*head);
//
查找学
生信息
voidRead(structstudent*head);
//
显示学
生信息
voidSort(structstudent*head);
//
链表节
点排序
struct
student
*
Create();
//
学生信息手动
录入
struct
student
*
Readpoint();
//
磁盘文件写入
内存
structstudent*Modify(structstudent*head);
//
链表结构
体成员修改
structstudent*Add(structstudent*head);
//
链表节
点插入
structstudent*Delete(structstudent*head);
//
链表节
点删除
教育资料
.
2.2.2、函数之间的调用关系:
通过switch语句进行指令选择:
case1:
学生信息录入
调用函数
Create()
、Save()、Menu_1()、Menu_2()
case2:
学生信息浏览
调用函数
Readpoint()、Sort()、Read()、Save()、Menu_1()、Menu_2()
case3:
学生信息查找
调用函数
Search()
、Readpoint()
、Menu_1()、Menu_2()
case4:
学生信息修改
调用函数
Modify()
、Readpoint()
、Save()、Menu_1()、Menu_2()
case5:
学生信息增加
调用函数
Add()、Readpoint()
、Save()、Menu_1()、Menu_2()
case6:
学生信息删除
调用函数
Delete()
、Readpoint()Save()
、Menu_1()、Menu_2()
case0:
返回主菜单
调用函数Menu_1()
第三章、代码(源代码)
/*
学生信息管理系统
*/
#include
#include
#include
structstudent//定义结构体
{
intnum;
charname[24];
charsex[5];
intChinese;
intMath;
intEnglish;
structstudent*next;
教育资料
.
};
voidMenu_1();
//
主菜单
voidMenu_2();
//
二级菜单
voidswap(structstudent*phead,structstudent*pback);
//
链表
节点互换
voidSave(structstudent*head);
//
写入
磁盘
voidSearch(structstudent*head);
//
查找
学生信息
voidRead(structstudent*head);
//
显示
学生信息
voidSort(structstudent*head);
//
链表
节点排序
structstudent*Readpoint();
//
磁盘
文件写入内存
structstudent*Create();
//
学生信息手动录入
structstudent*Modify(structstudent*head);
//
链表
结构体成员修改
structstudent*Add(structstudent*head);
//
链表
节点插入
structstudent*Delete(structstudent*head);
//
链表
节点删除
intmain(void)
{
Menu_1();
return0;
}
voidMenu_1()
{
intnum;
printf("\t\t\t\t
学生信息管理系统\t\t\t\t\n");
printf("\t\t\t1:
进入学生信息管理\n");
//
主菜单
printf("\t\t\t0:
退出学生信息管理\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{case1:
Menu_2();break;
教育资料
.
default:
printf("-----------------------------------------您已退出
学生信息管理系统-----------------------------------------------\n");
break;
}
}
/*------------------------------------------------------------------
------------------------------------------------------------------*/
voidMenu_2()
{
structstudent*head;
intnum;
printf("\t\t\t欢迎进入\n");
printf("------------------------------------------------------------
-----------------------------------------------------------\n");
printf("\t\t\t1:
学生信息录入\n");
printf("\t\t\t2:
学生信息浏览\n");
printf("\t\t\t3:
学生信息查找\n");
printf("\t\t\t4:
学生信息修改\n");
//二级菜单
printf("\t\t\t5:
学生信息增加\n");
printf("\t\t\t6:
学生信息删除\n");
printf("\t\t\t0:
返回主菜单\n");
printf("------------------------------------------------------------
------------------------------------------------------------\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
{
head=Create();
Save(head);
printf("\n");
printf("\t\t\t1:
返回主菜单\n");
//手动录入学生数据
printf("\t\t\t2:
返回二级菜单\n");
printf("\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
Menu_1();
break;
case2:
Menu_2();
教育资料
.
break;
default:
{
printf("输入无效,返回二级菜单!
\n");
Menu_2();
}
break;
}
}
break;
case2:
{
head=Readpoint();
//写入链表,返回头指针
Sort(head);
printf("\t\t\t以学号升序排列\n");Read(head);
//链表数据写入文件
Save(head);
printf("\n");
printf("\t\t\t1:
返回主菜单\n");
printf("\t\t\t2:
返回二级菜单\n");
printf("\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
Menu_1();
break;
case2:
Menu_2();
break;
default:
{
printf("输入无效,返回二级菜单!
\n");
Menu_2();
}
break;
}
}
break;
case3:
{
head=Readpoint();
Search(head);
//查找学生信息
教育资料
.
printf("\n");
printf("\t\t\t1:
返回主菜单\n");
printf("\t\t\t2:
返回二级菜单\n");
printf("\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
Menu_1();
break;
case2:
Menu_2();
break;
default:
{
printf("输入无效,返回二级菜单!
\n");
Menu_2();
}
break;
}
}
break;
case4:
{
head=Readpoint();
Modify(head);//
修改结构体成员并保存到文件
Save(head);
printf("\n");
printf("\t\t\t1:
返回主菜单\n");
printf("\t\t\t2:
返回二级菜单\n");
printf("\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
Menu_1();
break;
case2:
Menu_2();
break;
default:
{
printf("输入无效,返回二级菜单!
\n");
Menu_2();
}
break;
教育资料
.
}
}
break;
case5:
{
head=Readpoint();
Add(head);//增加学生信
息并保存到文件
Save(head);
printf("\n");
printf("\t\t\t1:
返回主菜单\n");
printf("\t\t\t2:
返回二级菜单\n");
printf("\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
Menu_1();
break;
case2:
Menu_2();
break;
default:
{
printf("输入无效,返回二级菜单!
\n");
Menu_2();
}
break;
}
}
break;
case6:
{
head=Readpoint();
head=Delete(head);
//删除学生信息并保存到文件
Save(head);
printf("\n");
printf("\t\t\t1:
返回主菜单\n");
printf("\t\t\t2:
返回二级菜单\n");
printf("\n");
printf("请您输入指令:
");
scanf("%d",&num);
switch(num)
{
case1:
Menu_1();
break;
教育资料
.
case2:
Menu_2();
break;
default:
{
printf("输入无效,返回二级菜单!
\n");
Menu_2();
}
break;
}
}
break;
case0:
Menu_1();
break;
default:
{
printf("请重新输入\n");
Menu_2();
}
break;
}
}
/*------------------------------------------------------------------
--------------------------------------------------------------------
-*/
structstudent*Create()
//学生信息手动录入
{
structstudent*head,*p,*q;
intn;
p=q=(structstudent*)malloc(sizeof(structstudent));
printf("请输入学生的姓名、学号、性别、语文成绩、高等数学成绩、英语
成绩:
\n");
scanf("%s",q->name);
scanf("%d%s%d%d%d",&q->num,&q->sex,&q->Chinese,&q->Math,&q->English);
n=0;
head=NULL;
while(q->num!
=0)
{
n=n+1;
if(n==1)
head=q;
else
教育资料
.
p->next=q;
p=q;
q=(structstudent*)malloc(sizeof(structstudent));
scanf("%s",q->name);
scanf("%d%s%d%d%d",&q->num,q->sex,&q->Chinese,&q->Math,&q->English);
}
p->next=NULL;
printf("学生信息录入成功!
\n");
returnhead;
}
/*------------------------------------------------------------------
--------------------------------------------------------------------
--*/
structstudent*Readpoint()
//学生信息写入内存,便于操作
{
FILE*fp1;
structstudent*head,*p,*q;intn;
if((fp1=fopen("E:
test.txt","rb"))==NULL)
{
printf("openfileerror!
\n");
exit(0);
}
p=q=(structstudent*)malloc(sizeof(structstudent));
fscanf(fp1,"%s%d%s%d%d%d",q->name,&q->num,q->sex,&q->Chinese,&q->Math,&q->English);
n=0;
head=NULL;
while(!
feof(fp1))
{
n=n+1;
if(n==1)
head=q;
else
p->next=q;
p=q;
教育资料
.
q=(structstudent*)malloc(sizeof(structstudent));
fscanf(fp1,"%s%d%s%d%d%d",&q->name,&q->num,&q->sex,&q->Chinese,&q->Math,&q->English);
}
p->next=NULL;
fclose(fp1);
returnhead;
}
/*------------------------------------------------------------------
--------------------------------------------------------------------
--*/
voidSwap(structstudent*phead,structstudent*pback)
//链表元素数据交换
{
structstudent*temp=(structstudent*)malloc(sizeof(structstudent));
strcpy(temp->name,phead->name);temp->num=phead->num;strcpy(temp->sex,phead->sex);temp->Chinese=phead->Chinese;temp->Math=phead->Math;temp->English=phead->English;
strcpy(phead->name,pback->name);
phead->num=pback->num;
strcpy(phead->sex,pback->sex);
phead->Chinese=pback->Chinese;
phead->Math=pback->Math;
phead->English=pback->English;
strcpy(pback->name,temp->name);
pback->num=temp->num;
strcpy(pback->sex,temp->sex);
pback->Chinese=temp->Chinese;
pback->Math=temp->Math;
pback->English=temp->English;
free(temp);
教育资料
.
}
/*------------------------------------------------------------------
--------------------------------------------------------------------
--*/
voidSort(structstudent*head)//学号排序
{
structstudent*phead=(structstudent*)malloc(sizeof(structstudent));
structstudent*pback=(structstudent*)malloc(sizeof(structstudent));
phead=head;
while(phead)
{
intNum=phead->num;
pback=phead->next;
while(pback)
{
if(Num>pback->num)
{
Swap(phead,pback);
Num=phead->num;
}
pback=pback->next;
}
phead=