C语言学生信息管理系统实验报告.docx

上传人:b****6 文档编号:4120292 上传时间:2022-11-28 格式:DOCX 页数:32 大小:20.40KB
下载 相关 举报
C语言学生信息管理系统实验报告.docx_第1页
第1页 / 共32页
C语言学生信息管理系统实验报告.docx_第2页
第2页 / 共32页
C语言学生信息管理系统实验报告.docx_第3页
第3页 / 共32页
C语言学生信息管理系统实验报告.docx_第4页
第4页 / 共32页
C语言学生信息管理系统实验报告.docx_第5页
第5页 / 共32页
点击查看更多>>
下载资源
资源描述

C语言学生信息管理系统实验报告.docx

《C语言学生信息管理系统实验报告.docx》由会员分享,可在线阅读,更多相关《C语言学生信息管理系统实验报告.docx(32页珍藏版)》请在冰豆网上搜索。

C语言学生信息管理系统实验报告.docx

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=

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 初中教育 > 政史地

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1