c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx

上传人:b****5 文档编号:17259577 上传时间:2022-11-29 格式:DOCX 页数:14 大小:315.58KB
下载 相关 举报
c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx_第1页
第1页 / 共14页
c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx_第2页
第2页 / 共14页
c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx_第3页
第3页 / 共14页
c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx_第4页
第4页 / 共14页
c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx_第5页
第5页 / 共14页
点击查看更多>>
下载资源
资源描述

c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx

《c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx》由会员分享,可在线阅读,更多相关《c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx(14页珍藏版)》请在冰豆网上搜索。

c语言程序设计报告材料 链表实现学生信息管理系统Word文档格式.docx

三.具体任务

由老师提供主菜单程序以及第0、2个模块。

学生在这个信息系统中加入四个模块,即:

1.浏览学生信息

3.删除学生信息

4.修改学生信息

5.保存学生信息

四、详细介绍

1、浏览学生信息

2、插入学生信息

3、删除学生信息

4、修改学生信息

5、信息的写入读出

6、学生信息的保存与释放

五、课程设计实践小节

这是这学期的第一次正式的程序设计,目的是运用链表来实现学生的学籍信息管理。

在学习过程中,我不仅把以前的函数循环搭配使用了起来,也接触到链表这些全新的概念。

链表的使用在今后的程序设计中尤为关键,他可以保存、调用和更改数据,在信息时代的程序设计中很重要。

在这次的程序设计中,老师和同学都是我强大的后盾。

比如之前在switch语句下的break的使用和getchar的重要性,还有在小程序里面的循环,每一步的程序都很重要。

通过这次的程序设计,我了解到我所感兴趣的东西并不是感兴趣就可以掌握的,要经过不断的练习和调试,在一次一次的失败中找到原因,团结周围的所有力量来突破。

最重要的收获其实还是写编码的重要性。

我这边接触过一些华为之类的程序设计员,他们都有c语言设计规范要求,每种固定程序的编写都有固定的格式,不按照格式的都有相应的处罚。

这次的程序设计中我充分的体会到了格式的重要性,我程序的最大的问题就在于switch语句里面格式的不对称导致的出错,最后是老师发现的,这是个极大的问题。

最后在这次的程序设计过程中感谢老师和帮助过我的同学!

六、源程序完整清单

#include<

stdio.h>

stdlib.h>

string.h>

malloc.h>

structnode

{

charnumber[12];

charname[10];

charsex[6];

charclasses[10];

chartel[12];

structnode*next;

};

typedefstructnodeNODE;

//函数的声明

voidBrowse(NODE*head);

voidInsert(NODE*head);

voidDelete(NODE*head);

voidModify(NODE*head);

voidWriteInfo(NODE*head);

voidReadInfo(NODE*head);

voidFreeList(NODE*head);

voidExit(NODE*head);

//主程序

intmain()

intchoice;

//avariableaccepttheuser'

schoice

NODE*head;

head=(NODE*)malloc(sizeof(NODE));

//creatheadnode

head->

next=NULL;

//installatail

ReadInfo(head);

//getinfofromdiskfileiffileexisted

while

(1)

{

//主菜单

printf("

\n%s"

"

*****学生信息管理系统******\n"

*1.浏览学生信息*\n"

*2.插入学生信息*\n"

*3.删除学生信息*\n"

*4.修改学生信息*\n"

*5.保存学生信息*\n"

*0.退出系统*\n"

*****************************\n"

请按功能代码选择(0~5):

"

);

scanf("

%d"

&

choice);

//numberwithreturncharintotheIObutter

getchar();

//clearthereturncharfrombuffer

switch(choice)

{

case1:

Browse(head);

break;

case2:

Insert(head);

case3:

Delete(head);

case4:

Modify(head);

case5:

WriteInfo(head);

case0:

Exit(head);

exit(0);

default:

printf("

\n选择错误,请重新输入!

\n"

}//endofswitch

}//endofwhile

(1)

return0;

}

//浏览学生信息

voidBrowse(NODE*head)

NODE*p=head;

if(p->

next==NULL)

无文件记录!

请输入学生信息!

return;

}

p=head->

next;

printf("

numbernameclassessextel\n"

-------------------------------------------\n"

while(p!

=NULL)

%s%s%s%s%s\n"

p->

number,p->

name,p->

classes,p->

sex,p->

tel);

p=p->

voidInsert(NODE*head)//定义插入函数

NODE*t,*p;

t=(NODE*)malloc(sizeof(NODE));

//createanewnodeandpointedbyt

p=head;

//pistopointtotheheadnode,whichispassedfrommainfunction

请输入学生学号:

scanf("

%s"

t->

number);

请输入学生姓名:

name);

请输入学生性别:

sex);

请输入学生班级:

classes);

请输入学生电话:

next==NULL)//原本无学生记录

p->

next=t;

//newnodeconnecttoheadnode

t->

//installatailforthenewnode

}

else//原本有学生记录

next=p->

//newnodeinserttotherearoftheheadnode.

//twosteps

voidDelete(NODE*head)//定义删除函数

NODE*p=head,*t=p->

charnum[12];

请输入要删除学生的学号:

num);

while(t!

if(strcmp(t->

number,num)!

=0)

t=t->

p=p->

else

p->

next=t->

free(t);

printf("

学生信息删除成功\n"

return;

该学生学号不存在,请输入正确的学生学号\n"

//修改学生信息

voidModify(NODE*head)

p=p->

请输入要修改信息的学生学号:

if(strcmp(p->

1.学号2.姓名3.性别4.班级5.电话\n请选择:

scanf("

switch(choice)

{

请输入要修改学生的学号:

scanf("

请输入要修改学生的姓名:

请输入要修改学生的性别:

请输入要修改学生的班级:

请输入要修改学生的电话:

}break;

//将学生信息写入文件

voidWriteInfo(NODE*head)

FILE*fp;

if((fp=fopen("

C:

\\Database.txt"

"

wb"

))==NULL)

不能打开学生文件!

return;

if(fwrite(p,sizeof(NODE),1,fp)!

=1)//writeinfoandchecksucessornot

写入学生文件错误!

fclose(fp);

//将学生信息从文件读出

voidReadInfo(NODE*head)

NODE*p=head,*t;

c:

rb"

学生数据文件不存在,或文件打不开!

p->

next=!

NULL;

while(p->

next!

t=(NODE*)malloc(sizeof(NODE));

fread(t,sizeof(NODE),1,fp);

//释放链表

voidFreeList(NODE*head)

NODE*p=head,*t=head;

free(t);

t=p;

//退出程序

voidExit(NODE*head)

charans;

intflag=1;

if(head->

{

保存当前数据吗?

请输入y/n:

while(flag)

%c"

&

ans);

getchar();

if(ans=='

y'

||ans=='

Y'

flag=0;

}

elseif(ans=='

n'

N'

else

输入错误,请重新输入y/n:

FreeList(head);

//releaseallnodes

再见,谢谢使用!

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

当前位置:首页 > PPT模板 > 可爱清新

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

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