ImageVerifierCode 换一换
格式:DOCX , 页数:37 ,大小:193.28KB ,
资源ID:12406173      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/12406173.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C语言课程设计报告学生成绩管理系统.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

C语言课程设计报告学生成绩管理系统.docx

1、C语言课程设计报告学生成绩管理系统学生成绩管理系统课程设计报告 2010-7-9一、程序整体规划:1.系统的基本功能数据的录入:如录入学生的基本信息,以及该学生选修课程的基本信息;数据的修改:如修改指定学号、或者指定姓名的学生信息,或者修改其选修课程信息;数据的插入:插入某个学生信息;数据的查询:如按学号查询、按姓名查询等;数据的删除:如删除指定学号、或者指定姓名的学生及其选修课程信息;平均成绩的计算:计算每个学生各门功课的平均成绩,并按平均成绩从高到低的次序输出学生信息;考虑用文件把数据保存起来2、首先是结构体的定义:typedef struct message_student char n

2、umber6; char name20; char sex4; float subjectnumsubs; float score; float average; int index;student;int numstus; 定义学生数目student *pointer; 指向结构体数组int lens; 次迟到时候分配内存3、部分重要函数声明:int menu_select(); 决定主界面的函数 int openfile(student stu); 打开文件的函数int findrecord(student stud); 查找信息的函数int writetotext(student stu

3、d); 保存文件的函数 void sort(student stu); 查找信息的函数void deleterecord(student stu,int i); 删除信息的函数void addrecord(student stud); 增加学生信息的函数void display(student stud,int n1,int n2); 数据的显示函数void sortnum(student stud); 以下几个均为排序函数void sortnum2(student stud); void sortname(student stud);void sortname2(student stud);

4、void sortcount(student stud);void sortcount2(student stud);4、设计思路1、主函数以switch和case语句引出其他子函数。然后进行其他子函数的调用。2、定义结构体student,让其包含如姓名性别等基本信息。同时定义结构体指针,以便后面子函数对某一项排序后输出该学生的全部信息。LENS给结构体数组分配内存。3、各个函数运行并相互调用其他子函数,例如几个排序函数全部被其它函数调用并输出结果。具体各子函数之间的关系见源代码。4、student stui表示的是一个结构体,内填大于等于0的数,这可以解释各个子函数中出现此类情况:例如str

5、cmp(str,studi.name)=0是该结构体内的第i+1个学生满足上述条件。由Studi.变量来引用各结构体中的变量,然后用输出函数相应输出该结构体内的信息。二程序模板细致分析:1.程序涉及的模板:主程序模板. 查询模块.删除模板. 将所有记录写入文件.输出模板.修改信息模板.录入信息模板. 和排序模板.排序模板可按如下进行分类:按学号:按学号降序排序模块.按学号升序排序模块.按姓名:按姓名降序排序模块. 按姓名升序排序模块. 按名次:按名次降序排序模块. 按名次升序排序模块. 2.功能结构联系图如下图所示: 现对各个功能的实现及个人认为每个功能中所用到的程序的闪光点和难点:1.增加学

6、生记录2已有记录是否覆盖:if(numstus!=0) printf(已有记录存在是否覆盖?(y/n)n); fflush(stdin); gets(str); if(str0=Y|str0=y) i=0;当输入数据过多时内存的扩展: (通过定义LENS开辟增加内存) if(numstuslens) lens+=50; pointer=(student *)realloc(pointer,lens*LEN);输入数字为1.0,但是结果输出为男.女: printf(请输入性别(男/女 1/0):); gets(studi.sex); if(studi.sex0=0) strcpy(studi.s

7、ex,女); else strcpy(studi.sex,男);2. 查询学生记录例: 按学号查找: if(str0=1) printf(请输入学号:); fflush(stdin); 亮点:清除数据缓冲区间 gets(str); for(i=0;i=numstus;i+) if(strcmp(str,studi.number)=0) 亮点:利用该函数将结构体数组中相应相同项联系在一起,确定其相应位置,便于输出。 display(stud,i,i); 子函数又调用了其他子函数 break; else continue;3修改学生记录 例:int i=-1,j; if(numstus=0) /*

8、没有记录返回*/ printf(没有可供修改的记录!); while(i=0) printf(要删除这个学生的信息吗?(y/n); 此处有一个难点就是while函数和调用其他子函数findrecord,以及解释为什么一开始要定义i为-1 4.学生纪录排序按学号:按学号降序排序模块.按学号升序排序模块.按姓名:按姓名降序排序模块. 按姓名升序排序模块. 按名次:按名次降序排序模块. 按名次升序排序模块.在排序过程中比较名次,成绩大小是不难的事情,名字通过STRCMPY函数来解决排序问题,但排序中的难点在于指针,结构体变量,结构体数组的综合应用,通过比较你的一组数据要输出所有该成员相应的信息,几个

9、排序中指针既指明了变量的地址,也指明了结构体数组的地址。此处感觉很棘手详细如下一条典型的例子:(其余的大致相同) student temp; student *p; p=stud; for(i=0;inumstus;i+) for(j=0;j0) temp=*(p+j); *(p+j)=*(p+j+1); *(p+j+1)=temp; 5打开文件和保存文件fgetc(fp); while(inumstus) fscanf(fp,%s,stui.number); fscanf(fp,%s,stui.name); fscanf(fp,%s,stui.sex); for(j=0;jnumsubs;j

10、+) fscanf(fp,%f,&stui.subjectj); fscanf(fp,%f,&stui.score); fscanf(fp,%f,&stui.average); fscanf(fp,%d,&stui.index); i+; 打开文件用函数fopen,fclose实现文件的打开,文件的关闭。其中按格式将内存中的数据转换成对应的ASCII字符,并以码形式输出到文本文件中保存文件先给所要保存的文件一个内存地址fp,然后将数据输入,数据存储过程中所用到的 fscanf将数据通过一个文件指针指向一个已打开的文本文件。此处的难点见函数的整体规划的详细说明。三、部分运行的图像主界面:纪录排序

11、:信息查找和修改文件保存和显示数据统计四程序主要代码include stdio.h#include string.h#include malloc.h#define H_STUDENT_HH#define LEN sizeof(struct message_student) /*一个结构体数组元素的长度*/#define numsubs 4 /*学科数目*/typedef struct message_student /*结构体定义*/ char number6; char name20; char sex4; float subjectnumsubs; float score; float

12、average; int index;student;int numstus; /*学生数目*/student *pointer; /*指向结构体数组*/int lens;int menu_select(); /*函数声明*/int openfile(student stu);int findrecord(student stud);int writetotext(student stud);void display1();void showtable();void sort(student stu); void deleterecord(student stu,int i);void add

13、record(student stud);void display(student stud,int n1,int n2);void amendrecord(student stud);void count(student stud);void sortnum(student stud);void sortnum2(student stud);void sortname(student stud);void sortname2(student stud);void sortcount(student stud);void sortcount2(student stud);void statis

14、tic(student stud);void display1();int menu_select() char c; int num;printf( nn 中南大学电气信息类学生信息管理系统 );printf( nn);printf( * 制作人:陈光尧 电气0916班 学号0909091611 n n);printf( nn); printf( *系统功能菜单*n n);printf( - - n);printf( n);printf( n); printf( 1. 增加学生记录 5.统计信息 n);printf( * n); printf( 2. 查询学生记录 6.打开文件 n);pri

15、ntf( * n);printf( 3. 修改学生记录 7.保存文件 n);printf( * n);printf( 4. 学生纪录排序 n);printf( * n);printf( n);printf( n); printf(请选择1-8:); fflush(stdin); c=getchar(); return (c);/*-查询模块-*/ int findrecord(student stud) /*查找信息*/ system(cls); char str20; int i,num; if(numstus=0) printf(没有可被查找的记录n); printf(按回车键退出); f

16、flush(stdin); getchar(); return -1; else printf(以何种方式查找?n1.学号t2.姓名t3.名次n); fflush(stdin); gets(str); if(str0=1) /*按学号查找*/ printf(请输入学号:); fflush(stdin); gets(str); for(i=0;i=numstus;i+) if(strcmp(str,studi.number)=0) display(stud,i,i); break; else continue; else if(str0=2) /*按姓名查找*/ printf(请输入姓名:);

17、gets(str); for(i=0;i=numstus;i+) if(strcmp(str,studi.name)=0) display(stud,i,i); break; else continue; else if(str0=3) /*按名次查找*/ printf(请输入名次:); fflush(stdin); scanf(%d,&num); for(i=0;inumstus) printf(没有查找所要的信息。n); printf(按回车键退出); fflush(stdin); getchar(); return -1; return i; int openfile(student s

18、tu) int i=0,j; FILE *fp; char filename20,str2; if(numstus!=0) printf(已经有记录存在,是否保存?(y/n); fflush(stdin); gets(str); if(str0=y|str0=Y) writetotext(stu); printf(请输入文件名:); fflush(stdin); gets(filename); numstus=0; if(fp=fopen(filename,rb+)=NULL) printf(无法打开该文件n); return(-1); fscanf(fp,%d,&numstus); fget

19、c(fp); while(inumstus) fscanf(fp,%s,stui.number); fscanf(fp,%s,stui.name); fscanf(fp,%s,stui.sex); for(j=0;jnumsubs;j+) fscanf(fp,%f,&stui.subjectj); fscanf(fp,%f,&stui.score); fscanf(fp,%f,&stui.average); fscanf(fp,%d,&stui.index); i+; fclose(fp); printf(文件读取成功n); printf(是否显示纪录?(y/n); fflush(stdin)

20、; gets(str); if(str0=y|str0=Y) display(stu,0,numstus-1); if(str0!=y&str0!=Y&str0!=n&str0!=N) printf(请输入n或者y!); gets(str); if(str0=y|str0=Y) display(stu,0,numstus-1); return(0);/*-排序模块-*/ void sort(student stud) int i,j=0; char str5; student *p; p=stud; if(numstus=0) printf(没有可供查询的记录!); while(1) for(

21、i=0;i+) printf( 请输入查询方式:); printf((直接输入回车则结束查询操作)n); printf(1.按照学号t); printf(2.按照姓名t); printf(3.按照名次n); fflush(stdin); gets(str); if(strlen(str)=0) break; if(str0=1) printf(请输入排序次序:n); printf(1.升序排列t); printf(2.降序排列n); gets(str); if(str0=1) sortnum2(p); else sortnum(p); display(stud,0,numstus-1); el

22、se if(str0=2) printf(请输入排序次序:n); printf(1.升序排列t); printf(2.降序排列n); gets(str); if(str0=1) sortname2(p); else sortname(p); display(stud,0,numstus-1); else if(str0=3) printf(请输入排序次序:n); printf(1.升序排列t); printf(2.降序排列n); gets(str); if(str0=1) sortcount2(p); else sortcount(p); display(stud,0,numstus-1);

23、else printf(请输入13); printf(是否退出排序?(y/n); gets(str); if(str0=y|str0=Y) break; return; /*-按学号降序排序模块-*/ void sortnum(student stud) int i,j; student temp; student *p; p=stud; for(i=0;inumstus;i+) for(j=0;j0) temp=*(p+j); *(p+j)=*(p+j+1); *(p+j+1)=temp; /*-按学号升序排序模块-*/ void sortnum2(student stud) int i,j

24、; student temp; student *p; p=stud; for(i=0;inumstus;i+) for(j=0;j0) temp=*(p+j); *(p+j)=*(p+j+1); *(p+j+1)=temp; /*-按姓名降序排序模块-*/ void sortname(student stud) int i,j; student temp; student *p; p=stud; for(i=0;inumstus;i+) for(j=0;j0) temp=*(p+j); *(p+j)=*(p+j+1); *(p+j+1)=temp; /*-按姓名升序排序模块-*/ void sortname2(student stud) int i,j; student temp; student *p; p=stud; for(i=0;inumstus;

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

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