用C语言编学生成绩管理系统
学生成绩管理系统c语言源代码
学生成绩管理系统c语言源代码介绍学生成绩管理系统是一个能够帮助学校、教师和学生管理和查询学生成绩的软件系统。
通过该系统,教师可以录入学生的考试成绩,并进行统计和分析;学生可以查询自己的成绩和排名;学校可以通过系统生成各种报表和分析数据。
本文将介绍一个使用C语言编写的学生成绩管理系统的源代码实现。
功能设计学生成绩管理系统的功能设计可以分为以下几个主要模块:登录模块1.输入用户名和密码;2.验证用户名和密码是否匹配;3.登录成功后进入主菜单。
学生管理模块1.输入学生信息(学号、姓名、性别、年龄等);2.添加学生信息到系统中;3.删除指定学号的学生信息;4.修改指定学号的学生信息;5.查询指定学号的学生信息;6.显示所有学生的信息。
课程管理模块1.输入课程信息(课程号、课程名称、授课教师等);2.添加课程信息到系统中;3.删除指定课程号的课程信息;4.修改指定课程号的课程信息;5.查询指定课程号的课程信息;6.显示所有课程的信息。
成绩管理模块1.输入学号和课程号;2.输入成绩信息(平时成绩、期末成绩、总评成绩等);3.添加成绩信息到系统中;4.修改指定学号和课程号的成绩信息;5.查询指定学号和课程号的成绩信息;6.统计指定课程的平均成绩、最高成绩和最低成绩;7.统计指定学生的平均成绩、最高成绩和最低成绩。
数据导入与导出模块1.从文件导入学生信息和成绩信息;2.将学生信息和成绩信息导出到文件。
源代码实现以下是一个使用C语言实现的学生成绩管理系统的源代码实例:#include <stdio.h>#include <stdlib.h>#include <string.h>// 定义学生结构体typedef struct {int id;char name[100];char gender[10];int age;} Student;// 定义课程结构体typedef struct {int id;char name[100];char teacher[100];} Course;// 定义成绩结构体typedef struct {int studentId;int courseId;float ordinaryGrade;float finalGrade;float totalGrade;} Grade;// 学生管理函数void addStudent(Student *students, int *studentCount) {// 添加学生信息到系统}void deleteStudent(Student *students, int *studentCount, int studentId) { // 删除指定学号的学生信息}void modifyStudent(Student *students, int studentId) {// 修改指定学号的学生信息}void queryStudent(Student *students, int studentId) {// 查询指定学号的学生信息}void displayAllStudents(Student *students, int studentCount) { // 显示所有学生的信息}// 课程管理函数void addCourse(Course *courses, int *courseCount) {// 添加课程信息到系统}void deleteCourse(Course *courses, int *courseCount, int courseId) { // 删除指定课程号的课程信息}void modifyCourse(Course *courses, int courseId) {// 修改指定课程号的课程信息}void queryCourse(Course *courses, int courseId) {// 查询指定课程号的课程信息}void displayAllCourses(Course *courses, int courseCount) {// 显示所有课程的信息}// 成绩管理函数void addGrade(Grade *grades, int *gradeCount) {// 添加成绩信息到系统}void modifyGrade(Grade *grades, int gradeCount, int studentId, int courseId) { // 修改指定学号和课程号的成绩信息}void queryGrade(Grade *grades, int gradeCount, int studentId, int courseId) { // 查询指定学号和课程号的成绩信息}void calculateCourseStatistics(Grade *grades, int gradeCount, int courseId) { // 统计指定课程的平均成绩、最高成绩和最低成绩}void calculateStudentStatistics(Grade *grades, int gradeCount, int studentId) {// 统计指定学生的平均成绩、最高成绩和最低成绩}// 数据导入与导出函数void importData() {// 从文件导入学生信息和成绩信息}void exportData() {// 将学生信息和成绩信息导出到文件}int main() {// 主程序菜单return 0;}总结学生成绩管理系统是一个非常有用的工具,可以帮助学校、教师和学生高效地管理和查询学生成绩。
用C语言实现学生成绩管理系统
int j,i;
printf("\n\n\n\t\t输出按学号排序的成绩表");
headno=(linklist)malloc(sizeof(Nodest));
p->next=q->next;
q->next=p;
}
} p=input_record();
scanf("%s",);
for(i=1;i<=NUM;i++)
{
printf("\t\t %s:",kname[i]);
p=p->next;
if(p!=NULL)
{
p->next=p->next->next;
return hsort;
}
else
}
return head;
}
linklist input_record()
{
linklist p;
student x;
int i;
x.total=0;
p=NULL;
strcpy(s->stu.no,p->stu.no);
for(i=1;i<=NUM;i++)
s->stu.score[i]=p->stu.score[i];
getchar();
}
void del()
{
linklist p,key_delect();
char x[10];
printf("\t删除模块\n");
学生成绩管理系统代码(c语言编写)
C程序学生管理系统/* Note:Your choice is C IDE */#include"stdio.h"#include"stdlib.h"#include"string.h"typedef struct student//定义学生{char name[10];int number;char sex[2];int math;int eglish;int clanguge;int average;}student;typedef struct unit//定义接点{student date;struct unit *next;}unit;unit* build()//建立链表并返回指针{unit *p;if((p=(unit*)malloc(sizeof(unit)))==NULL) { printf("=>初始化失败!");return 0;}else{p->next=NULL;p->date.number=0;//头结点存放学生人数 printf("初始化成功!\n");return p;}}void add(unit *head)//增加学生{unit *p,*q;int m,n=0;q=head->next;p=(unit*)malloc(sizeof(unit));printf("=>请输入新生姓名!\n");gets(p->);fflush(stdin);printf("=>请输入学号!\n");while(n==0){scanf("%d",&m);fflush(stdin);if(q==NULL) n=1;while(q){if(q->date.number==m){printf("=>你输入的学号与已有同学的学号相同,请重新输入!\n");q=head->next;break;}else{q=q->next;if(q==NULL) n=1;}}}p->date.number=m;printf("=>请输入性别!\n");gets(p->date.sex);fflush(stdin);printf("=>请输入数学成绩\n");scanf("%d",&m);fflush(stdin);p->date.math=m;printf("=>请输入英语成绩\n");scanf("%d",&m);fflush(stdin);p->date.eglish=m;printf("=>请输入c语言成绩\n");scanf("%d",&m);fflush(stdin);p->date.clanguge=m;p->date.average=(p->date.math+p->date.eglish+p->date.clanguge);q=head->next;head->next=p;p->next=q;head->date.number++;}void deletion(unit *head)//删除一名学生{unit *p=head->next,*q=head;char N[10];printf("=>请输入你想删除的学生姓名!\n");gets(N);fflush(stdin);if(p==NULL)printf("=>系统无学生可删除!\n");while(p){if(strcmp(p->,N)==0){q->next=p->next;head->date.number--;printf("=>删除%s成功!\n",p->);free(p);break;}else{p=p->next;q=q->next;if(p==NULL)printf("=>你要删除的学生不存在,删除失败!\n");}}}int display(unit *head)//显示学生信息{unit *p=head->next;int m,n=0;char N[10];if(p==NULL){printf("=>系统无学生!\n");return 0;}while(n==0){printf("********************************************************* *********************\n");printf("=>请选择你的操作!\n");printf("=>\t\t\t1.显示所有\t2.按姓名查找\n\t\t\t3.按学号查找\t4.返回主菜单\n");scanf("%d",&m);fflush(stdin);switch(m){case 1:printf("\n=>该系统拥有%d名学生!\n\n",head->date.number);p=head->next;printf("\t姓名\t学号\t性别\t数学\t英语\tc语言\t综合\n\n");while(p){printf("\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n",p->,p->date.numb er,p->date.sex,p->date.math,p->date.eglish,p->date.clanguge,p->date.average);p=p->next;}break;case 2:printf("=>请输入查找姓名!\n");gets(N);fflush(stdin);p=head->next;while(p){if(strcmp(p->,N)==0){printf("\t姓名\t学号\t性别\t数学\t英语\tc语言\t 综合\n");printf("\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n",p->,p->date.numb er,p->date.sex,p->date.math,p->date.eglish,p->date.clanguge,p->date.average);break;}else{p=p->next;if(p==NULL)printf("=>你要查的学生不存在!");}}break;case 3: printf("=>请输入查找学号!\n");scanf("%d",&m);fflush(stdin);p=head->next;while(p){if(p->date.number==m){printf("\t姓名\t学号\t性别\t数学\t英语\tc语言\t 综合\n");printf("\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n",p->,p->date.numb er,p->date.sex,p->date.math,p->date.eglish,p->date.clanguge,p->date.average);break;}else{p=p->next;if(p==NULL)printf("=>你要查的学生不存在!\n");}}break;case 4:n=1;break;}}return 1;}int range(unit *head)//排序{unit *p=head,*q=head->next;int n,i,m=head->date.number;printf("********************************************************* **********************\n");printf("\t\t\t1.按学号\t2.按成绩\n\n");printf("=>请选择操作!\n》");scanf("%d",&n);fflush(stdin);if(q==NULL){ printf("=>无学生可排序!\n");return 0;}switch(n){case 2:for(i=0;i<m;i++)//按总分排序{p=head;q=head->next;while(q->next){if((q->date.average)<(q->next->date.average)){p->next=q->next;p=p->next;q->next=p->next;p->next=q;}else{p=p->next;q=q->next;}}}break;case 1:for(i=0;i<=m;i++)//按学号排序{p=head;q=head->next;while(q->next){if((q->date.number)>(q->next->date.number)){p->next=q->next;p=p->next;q->next=p->next;p->next=q;}else{p=p->next;q=q->next;}}}break;}printf("=>排序成功!\n");return 1;}void menu(){printf("\n********************************* 主菜单***************************************\n");printf("\t\t\t1.新建系统\t2.添加学生\n\t\t\t3.删除学生\t4.查看信息\n\t\t\t5.排列顺序\t6.读取信息\n\t\t\t7.保存信息\t8.退出系统\n");printf("=>请选择你的操作!\n");}int save(unit *head)//保存{FILE *fp;unit *p;p=head;if((fp=fopen("d:\\学生","wb+"))==NULL){printf("=>保存失败!");return 0;}while(p){fwrite(&(p->date),sizeof(student),1,fp);p=p->next;}printf("=>保存成功!");fclose(fp);return 1;}unit* read()//读入系统学生信息{int i;unit *p,*q,*head;FILE *fp;if((head=(unit*)malloc(sizeof(unit)))==NULL) { printf("=>开辟空间失败!");exit(1);}else{head->next=NULL;head->date.number=0;//头结点存放学生人数}q=head;if((fp=fopen("d:\\学生","rb"))==NULL){printf("=>系统无学生!\n");return 0;}fread(&(q->date),sizeof(student),1,fp);for(i=0;i<head->date.number;i++){if((p=(unit*)malloc(sizeof(unit)))==NULL){ printf("=>读值失败!");exit(1);}fread(&(p->date),sizeof(student),1,fp);p->next=q->next;q->next=p;}fclose(fp);return head;}void main(){int m=0,n, i;unit *head;printf("************************************************************* *******************\n\n");printf("\t\t\t* 欢迎使用学生成绩管理系统 * \n");printf("\n\t\t\t\t\t\t\t\t编译员:岳英明\n\n");printf("=>正在读取系统信息......\n");if((head=read())==0){printf("=>是否新建?\n");printf("\t\t\t是(1)\t\t否(2)\n");scanf("%d",&i);fflush(stdin);if(i==1)head=build();else if(i==2)exit(1);}elseprintf("=>信息导入成功!");while(m==0){menu();scanf("%d",&n);fflush(stdin);switch(n){case 1: head=build();break;case 2:add(head);break;case 3:deletion(head);break;case 4:display(head);break;case 5: range(head);break;case 6:head=read();if(head!=0) printf("=>读取存盘成功!\n");break;case 7:save(head);break;case 8:m=1;break;}}}。
学生成绩管理系统C语言版
1、2、编一程序,能计算每个学生的总分和平均分。
3、编一程序,能按输入要求打印各门课程的最高分和最低分的同学。
4、编一程序,能将五个学生的成绩按总分进行降序排序。
5、编一程序,能删除一个学生的记录;6、编一程序,能增加一个学生的记录;建立一个菜单模式的学生信息管理系统,完成功能如下:一、建立主菜单*****学生信息管理系统*****1、输入学生信息2、输出学生信息3、计算每个同学成绩的总分与平均分4、对学生成绩进行排序5、输出每门功课最高分的同学信息6、输出每门功课最低分的同学信息7、退出系统主菜单界面:二、将综合练习一中的程序改写为子程序并能通过主菜单进行调用。
先上图开发环境windows 7,vc 6.0 开始贴代码:/*************** 张海山* 10软件2班* 安庆职业技术学院* QQ:136533295******************/#include"stdio.h"#include"stdlib.h"#include"malloc.h"#include"string.h"typedef struct lode{int id;char name[20];char sex[10];int score[4];struct lode *next;}lode,*linklist;linklist input(linklist head)//输入学生信息{char cmd='y';int t,i,l;char name[10];char sex[2];int score[3]={0};//int sum;linklist p;while(cmd=='y'||cmd=='Y'){p=(linklist)malloc(sizeof(lode));printf("请输入学生的编号\n");fflush(stdin);scanf("%d",&t);p->id=t;printf("请输入学生的姓名:\n");fflush(stdin);scanf("%s",p->name);/* l=strlen(p->name);p->sex[l]='\0';/* for(i=0;i<l;i++){p->name[i]=name[i];}*/printf("请输入学生的性别:\n");fflush(stdin);scanf("%s",p->sex);/* l=strlen(p->sex);p->sex[l]='\0';/* for(i=0;i<l;i++){p->sex[i]=sex[i];}*/fflush(stdin);printf("请依次输入学生的三门课成绩:\n");scanf("%d",&score[0]);p->score[0]=score[0];fflush(stdin);scanf("%d",&score[1]);p->score[1]=score[1];fflush(stdin);scanf("%d",&score[2]);p->score[2]=score[2];fflush(stdin);p->next=head->next;head->next=p;printf("是否继续(y)&返回主菜单(n) y&n\n");fflush(stdin);scanf("%c",&cmd);}return head;}linklist print(linklist head){linklist p;int i=1;p=head->next;printf("\t序号\t姓名\t性别\t英语\t数学\t语文\n");while(p!=NULL){printf("\t%d\t%s\t%s\t%d\t%d\t%d\n",p->id,p->name,p->sex,p->score[0],p->score[1],p->sco re[2]);p=p->next;/*if(p==NULL)break;printf("%d\n",i);*/}//printf("%d\n",i);//printf("i=%d\n",i);return 0;}void avg(linklist head){int sum=0;double avg=0;linklist p;p=head->next;while(p!=NULL){sum=0;sum=p->score[1]+p->score[2]+p->score[0];avg=sum/3;printf("%s的总分为:%d\t平均分为:%.2lf\n",p->name,sum,avg);p=p->next;}}void maxmin(linklist head){linklist p;intmax1=0,max1index,min1=head->next->score[0],min1index,max2=0,max2index,min2=head->nex t->score[1],min2index,max3=0,max3index,min3=head->next->score[2],min3index;p=head->next;while(p!=NULL){if(max1<(p->score[0])){max1=p->score[0];max1index=p->id;}if(min1>=(p->score[0])){min1=p->score[0];min1index=p->id;}if(max2<(p->score[1])){max2=p->score[1];max2index=p->id;}if(min2>=(p->score[1])){min2=p->score[1];min2index=p->id;}if(max3<(p->score[2])){max3=p->score[2];max3index=p->id;}if(min3>=(p->score[2])){min3=p->score[2];min3index=p->id;}p=p->next;}printf("英语:\n");p=head->next;while(p!=NULL){if((p->id)==max1index)printf("英语最高分为:%d\t姓名为:%s\n",p->score[0],p->name);if((p->id)==min1index)printf("英语最低分为:%d\t姓名为:%s\n",p->score[0],p->name);p=p->next;}printf("数学:\n");p=head->next;while(p!=NULL){if((p->id)==max2index)printf("数学最高分为:%d\t姓名为:%s\n",p->score[1],p->name);if((p->id)==min2index)printf("数学最低分为:%d\t姓名为:%s\n",p->score[1],p->name);p=p->next;}printf("语文:\n");p=head->next;while(p!=NULL){if((p->id)==max3index)printf("语文最高分为:%d\t姓名为:%s\n",p->score[2],p->name);if((p->id)==min3index)printf("语文最低分为:%d\t姓名为:%s\n",p->score[2],p->name);p=p->next;}}void rank(linklist head){linklist p;int i=0,j,k,n=0;int sum[100];p=head->next;while(p!=NULL){n++;sum[i]=p->score[1]+p->score[2]+p->score[0];i++;p=p->next;}printf("n=%d\n",n);for(i=1;i<6;i++){for(j=0;j<6-i;j++)if(sum[j]<sum[j+1]){k=sum[j];sum[j]=sum[j+1];sum[j+1]=k;}}printf("\t序号\t姓名\t性别\t英语\t数学\t语文\n");for(i=0;i<n;i++){p=head->next;while(p!=NULL){if(sum[i]==(p->score[1]+p->score[2]+p->score[0])){printf("\t%d\t%s\t%s\t%d\t%d\t%d\n",p->id,p->name,p->sex,p->score[0],p->score[1],p->sco re[2]);break;}p=p->next;}}}void add(linklist head){linklist p,q;p=head;q=(linklist)malloc(sizeof(lode));printf("请输入要插入学生的序号:\n");fflush(stdin);scanf("%d",&q->id);fflush(stdin);printf("请输入学生的姓名:\n");scanf("%s",q->name);fflush(stdin);printf("请输入学生性别:\n");scanf("%s",q->sex);fflush(stdin);printf("请依次输入学生的三门课成绩:\n");scanf("%d",&q->score[0]);fflush(stdin);scanf("%d",&q->score[1]);fflush(stdin);scanf("%d",&q->score[2]);fflush(stdin);q->next=NULL;while(p->next!=NULL){p=p->next;}p->next=q;//p->next=NULL;}void del(linklist head){linklist p,temp;int j;p=head->next;temp=head;printf("请输入要删除学生记录的序号:\n");scanf("%d",&j);while(p!=NULL){if(p->id!=j){p=p->next;temp=temp->next;}else{temp->next=p->next;free(p);break;}}}void main(){int cmd;linklist head;head=(linklist)malloc(sizeof(lode));head->next=NULL;do{printf("\n\n |***************学生成绩管理程序***************|\n");printf(" |----------------------------------------------|\n");printf(" | |\n");printf(" | 主菜单|\n");printf(" | |\n");printf(" |----------------------------------------------|\n");printf(" | |\n");printf(" | 请输入选择项目:|\n");printf(" | |\n");printf(" | 1、输入学生成绩|\n");printf(" | |\n");printf(" | 2、输出学生成绩|\n");printf(" | |\n");printf(" | 3、计算总成绩、平均成绩|\n");printf(" | |\n");printf(" | 4、求最高分、最低分|\n");printf(" | |\n");printf(" | 5、排序|\n");printf(" | |\n");printf(" | 6、增加记录|\n");printf(" | |\n");printf(" | 7、删除记录|\n");printf(" | |\n");printf(" | 0、退出系统|\n");printf(" | |\n");printf(" |----------------------------------------------|\n");scanf("%d",&cmd);switch(cmd){case 0:break; //退出系统case 1: input(head);break; //输入学生信息case 2: print(head);break; //输出学生信息case 3: avg(head);break; //求总成绩、平均数case 4: maxmin(head);break; //最高分case 5: rank(head);break; //排序case 6: add(head);break; //增加记录case 7: del(head);break; //删除记录default :printf("您输入错误!\n");}}while(cmd!=0);}因为是C语言版的要严格按照样子输入哦要不然就会出现不可预料的结果。
学生成绩管理系统C语言(附完整源代码)
学生成绩管理系统 C 语言(附完整源代码) 课程设计报告学生成绩管理系统院系: 专业: 班级: 完成日期: 2009 年1月03日设计题目: 学生成绩管理系统目录1、题目描述2、算法设计/ 设计思想3、结构框图、各模块的功能描述4、主体思想:5、程序的,,, 流程图6、源代码1. 题目描述设计一个简单的学生成绩管理系统,要求有简单的界面,程序段要分清模块,该程序应该:(1) 输入学生成绩, 求总分,平均分,以及排序。
(2) 查询学生单科成绩,总分和平均成绩;(3) 添加、修改学生成绩具有下列功能:(4) 实现保存与查看功能2. 算法设计/ 设计思想利用二维数组——定义stu[][] 存储学生学号、各科成绩,总分,平均分, 名次, 利用文件来存储,读取数据。
具体分工是:: 负责inputx(),print1(),input();: 负责文件的存储和读取,main(),System(),Idea() 以及各调用函数之间的连: 负责find1(),find2(),find3(),find31(),Find();: 负责del(),add(),change1(),Change(); 后期调试由小组共同负责。
3. 结构框图、各模块的功能描述3.1 创建成绩表3.1.1 input() 功能是输入学生的信息,便于以后的查询、浏览。
3.2 添加3.2.1 add( ) 功能是向inputy() 添加新的内容。
3.3.2 chance( ) 对单科成绩进行修改。
3.3 查询3.3.1 可根据学号, 科目, 名次,进行查询。
3.3.2 查询内容包括: 该学生的各课成绩、、平均分。
3.4 删除3.4.1 可以输入学号删除一名学生的一课成绩。
3.5 浏览成绩单3.5.1 通过此print1() 可以查看所有学生的各课成绩、总分、平均分和名次。
3.6 文件()3.6.1 保存以上所输入的信息以达到既是关闭窗口信息也不会丢失信息的目的。
C语言课程设计学生成绩管理系统
PART THREE
学生信息包括:姓名、学号、性别、班级、成绩等 学生信息录入方式:手动输入、文件导入、数据库查询等 学生信息录入界面设计:简洁明了,易于操作 学生信息录入注意事项:确保信息准确无误,避免重复录入
查询结果:显示学生的基本 信息、成绩、课程等信息
系统故障分类:硬件故障、软件故障、网络故障等 故障处理流程:发现故障、分析原因、采取措施、恢复系统 应急预案:制定应急预案、定期演练、及时更新 数据备份与恢复:定期备份数据、灾难恢复计划
汇报人:
,a click to unlimited possibilities
汇报人:
CONTENTS
PART ONE
PART TWO
目标:实现学 生成绩的高效
管理
功能:学生信 息管理、成绩 录入、成绩查 询、成绩统计、 成绩分析、成
绩排名等
系统用户:学生、教师、管理员
权限设置:学生只能查看自己的成绩,教师可以查看和管理所有学生的成绩,管理员可以管理所有用户和权限
查询和报表的界面设计:简 洁明了,易于操作
查询和报表的数据处理:高效、 准确,保证数据的一致性和完 整性
PART SIX
数据备份:定期备份数据,防止数据丢失 数据恢复:在数据丢失或损坏时,能够快速恢复数据 备份策略:制定合理的备份策略,确保数据的完整性和一致性 备份工具:使用专业的备份工具,提高备份效率和可靠性
删除方式:通过学生ID进行 删除
删除条件:学生信息存在且 未被删除
删除操作:在数据库中执行 删除语句
删除结果:学生信息从数据库 中被删除,系统提示删除成功
PART FOUR
学生成绩管理系统基本C语言编写
//代码版权所有,不要#include "stdio.h" #include "stdlib.h" #include "string.h"#include "conio.h" copy,仅供参考学习。
//标准输入输出函数库//标准函数库//字符串函数库//屏幕操作函数库#definep->data.num,p->,p->data.egrade,p->data.mgrade,p->data.cgrade,p->data.total,p->data.a ve,p->data.mingciint saveflag=0; //是否需要存盘的标志变量//定义与学生有关的数据结构typedef structstudent {char num[12]; charname[15]; intcgrade; intmgrade; integrade; int total;float ave; intmingci;}sqlist;//定义每条记录或结点的数据结构,标记为:nodetypedef struct node{struct student data;// 数据域struct node *next; //指针域}Node,*Link; //Node 为node 类型的结构变量,*Link 为node 类型的指针变量void menu() //主菜单{system("cls"); //调用DOS 命令,清屏.与clrscr() 功能相同printf(" \n");printf(" 学生成绩管理信息系统主菜单\n\n");printf(" **************************************************\n");printf(" $ 1、添加记录6、统计记录$\n");printf(" $ 2、删除记录7、排序记录$\n");#define HEADER1 " ***************************学生成绩信息****************************** \n\n"#define HEADER2 " 学号姓名计算机数学英语总分平均分名次\n\n"#define FORMAT " %-10s %-10s %5d %5d %5d %5d %.3f %4d \n" DATA//标记为student//学号//姓名//计算机成绩//数学成绩//英语成绩//总分//平均分//名次}void printheader() // 格式化输出表头{printf(HEADER1);printf(HEADER2);}void printdata(Node *pp) // 格式化输出表中数据{Node* p; p=pp;printf(FORMA T,DA TA);}void Wrong()//输出按键错误信息{printf("\n\n\n\n\n**********Error: 输入错误 !请按任意键继续 !!**********\n"); getchar();}void Nofind()//输出未查找此学生的信息{ printf("\n=====> 未查找此学生的信息 !\n");}void Disp(Link l)//显示单链表 l 中存储的学生记录,内容为 student 结构中定义的内容{Node *p;p=l->next; //l 存储的是单链表中头结点的指针,该头结点没有存储学生信 息,指针域指向的后继结点才有学生信息if(!p) //p==NULL,NUll 在 stdlib 中定义为 0 {printf("\n=====> 无学生的记录 !\n"); getchar(); return;}printf("\n\n"); printheader(); while(p) //逐条输出链表中存储的学生信息{printdata(p); p=p->next;// 移动直下一个结点}getchar(); getchar();}/*作用:用于定位链表中符合要求的节点,并返回指向该节点的指针参数: findmess[] 保存要查找的具体内容 ; nameornum[] 保存按什么查找 ;在单链表 l 中查找 ;*/printf(" $3、 查找记录 8、 保存记录$\n"); printf(" $4、 修改记录 9、 显示记录 $\n"); printf("$5、 插入信息 0、 退出系统 $\n");printf("************************************************ **\n");//输出表格头部Node* Locate(Link l,char findmess[],char nameornum[]){Node *r; if(strcmp(nameornum,"num")==0) //按学号查询{r=l->next;while(r){ if(strcmp(r->data.num,findmess)==0) //若找到findmess 值的学号return r;r=r->next;}}else if(strcmp(nameornum,"name")==0) //按姓名查询{r=l->next;while(r){ if(strcmp(r->,findmess)==0) // 若找到findmess 值的学生姓名return r;r=r->next;}}return 0; // 若未找到,返回一个空指针}//输入字符串,并进行长度验证(长度<lens) void stringinput(char *t,int lens,char *notice) { char n[255]; doprintf(notice); //显示提示信息scanf("%s",n); //输入字符串if(strlen(n)>lens)printf("\n 超出长度范围,重新输入! \n"); // 进行长度校验,超过lens 值重新输入}while(strlen(n)>lens);strcpy(t,n); // 将输入的字符串拷贝到字符串t 中}//输入分数,0< =分数< =100)int numberinput(char *notice){int t=0;do{printf(notice); //显示提示信息scanf("%d",&t); //输入分数if(t>100 || t<0)printf("\n 分数必须在0到100之间! \n"); //进行分数校验}while(t>100 || t<0);return t;}//增加学生记录void Add(Link l){Node *p,*r,*s; //实现添加操作的临时的结构体指针变量char ch,flag=0,num[12];r=l;s=l->next;system("cls");Disp(l); //先打印出已有的学生信息while(r->next!=NULL)r=r->next; //将指针移至于链表最末尾,准备添加记录while(1) //一次可输入多条记录,直至输入学号为0 的记录结点添加操作{while(1) //输入学号,保证该学号没有被使用,若输入学号为0,则退出添加记录操作stringinput(num,12,"\n输入学号(按“0”返回菜单!):"); //格式化输入学号并检验flag=0; if(strcmp(num,"0")==0) // 输入为0,则退出添加操作,返回主界面{return;}s=l->next;while(s) //查询该学号是否已经存在,若存在则要求重新输入一个未被占用的学号{ if(strcmp(s->data.num,num)==0) {flag=1; break;} s=s->next;}if(flag==1) //提示用户是否重新输入{ getchar(); printf("=====> 学号%s 存在,重试?(y/n):",num); scanf("%c",&ch);if(ch=='y'||ch=='Y') continue;elsereturn;}else{ break;}}p=(Node *)malloc(sizeof(Node)); //申请内存空间if(!p){printf("\n 内存空间申请失败! "); // 如没有申请到,打印提示信息return ; //返回主界面} strcpy(p->data.num,num); //将字符串num 拷贝到p->data.num 中stringinput(p->,15," 姓名:");p->data.cgrade=numberinput(" 计算机[0-100]:"); // 输入并检验分数,分数必须在0-100 之间p->data.mgrade=numberinput(" 数学[0-100]:"); //输入并检验分数,分数必须在0-100 之间p->data.egrade=numberinput(" 英语[0-100]:"); //输入并检验分数,分数必须在0-100 之间p->data.total=p->data.egrade+p->data.cgrade+p->data.mgrade; // 计算总分p->data.ave=(float)(p->data.total/3); //计算平均分p->data.mingci=0;r->next=p; // 将新建的结点加入链表尾部中p->next=NULL; // 表明这是链表的尾部结点r=p;saveflag=1;}return ;}//按学号或姓名,查询学生记录void Qur(Link l){int select; //1: 按学号查,2:按姓名查,其他:返回主界面(菜单)char searchinput[20]; //保存用户输入的查询内容Node *p;if(!l->next) //若链表为空{system("cls"); printf("\n=====> 无此学生的记录!\n"); getchar();return;}system("cls");printf("\n =====>1 按学号查询=====>2 按名字查询\n");printf(" 请选择[1,2]:");scanf("%d",&select);if(select==1) //按学号查询{stringinput(searchinput,12," 请输入现有学生的学号:"); p=Locate(l,searchinput,"num");// 在l 中查找学号为searchinput 值的节点,并返回节点的指针if(p){ printheader(); printdata(p); printf(" 按任意键返回!");getchar();}elseNofind(); getchar();}else if(select==2) //按姓名查询{stringinput(searchinput,15," 请输入现有学生的姓名:"); p=Locate(l,searchinput,"name");if(p){ printheader(); printdata(p);printf(" 按任意键返回!"); getchar();}elseNofind(); getchar();}elseWrong();getchar();}//删除学生记录:先找到保存该学生记录的节点,然后删除该节点void Del(Link l){int sel;Node *p,*r;char findmess[20]; if(!l->next){system("cls");printf("\n=====> 无此学生记录!\n");getchar();return;} system("cls");Disp(l);printf("\n =====>1 按学号删除=====>2 按姓名删除\n");printf(" 请选择[1,2]:");scanf("%d",&sel);if(sel==1){stringinput(findmess,12," 请输入现有学生的学号:"); p=Locate(l,findmess,"num");if(p){r=l;while(r->next!=p)r=r->next;r->next=p->next; //将p 所指节点从链表中去除free(p); //释放内存空间printf("\n=====> 删除成功!\n");getchar(); saveflag=1;}elseNofind();getchar();}else if(sel==2) //先按姓名查询到该记录所在的节点{stringinput(findmess,15," 请输入现有学生的姓名"); p=Locate(l,findmess,"name");if(p){r=l;while(r->next!=p)r=r->next;r->next=p->next;free(p); printf("\n=====> 删除成功!\n"); getchar();saveflag=1;}elseNofind(); getchar();}elseWrong();getchar();}}//修改学生记录。
C语言编写的简单的学生成绩管理系统收藏
#include<stdio.h>#include<string.h>struct student{int num;char name[20];int score;}stu[6];int i;void main(){void in();void xianshi();void paixu();void charu();void shanchu();void chaxian();void g(); int n;while(n!=8){printf("\n\t\t\t学生管理系统");printf("\n\t\t1:输入一个班的学生信息\n");printf("\t\t2:显示所有学生的信息\n");printf("\t\t3:按学号对所有学生排序\n");printf("\t\t4:插入一条学生信息按学号排好\n");printf("\t\t5:按姓名查找,并删除一条信息\n");printf("\t\t6:查找并显示一条信息\n");printf("\t\t7:求出全班平均成绩,显示最高分最低分\n");printf("\t\t8:退出系统\n");printf("输入选项代码:");scanf("%d",&n);switch(n){case 1:in();break;case 2:xianshi();break;case 3:paixu();break;case 4:charu();break;case 5:shanchu();break;case 6:chaxian();break;case 7:g();break;case 8:printf("谢谢使用!\n");break;break;}}getchar();}void in() /* 输入一个班的学生信息*/{for(i=0;i<5;i++){ printf("请输入学号姓名成绩:\n");scanf("%d%s%d",&stu[i].num,stu[i].name,&stu[i].score);}}void xianshi(){ int i;printf("学号姓名成绩\n");for(i=0;i<5;i++)printf("%d%10.2s%10d\n",stu[i].num,stu[i].name,stu[i].score);}void paixu()/* 按学号对所有信息排序*/{ int a[5]={0,1,2,3,4};int i,j,temp;for(i=0;i<4-j;i++)if(stu[a[i]].num>stu[a[i+1]].num){ temp=a[i];a[i]=a[i+1];a[i+1]=temp;}printf("顺序为:\n");printf("学号姓名成绩\n");for(i=0;i<5;i++)printf("%d%10.2s%10d\n",stu[a[i]].num,stu[a[i]].name,stu[a[i]].score); printf("\n");}void charu()/*插入一条学生信息按学号排列*/{int i;printf("请输入要插入学生的学号姓名成绩:");scanf("%d%s%d",&stu[5].num,stu[5].name,&stu[5].score);for(i=0;i<5;i++)printf("%d%s%d\n",stu[i].num,stu[i].name,stu[i].score);{int a[6]={0,1,2,3,4,5};int i,j,temp;for(j=0;j<5;j++){ for(i=0;i<5-j;i++)if(stu[a[i]].num>stu[a[i+1]].num){ temp=a[i];a[i]=a[i+1]; a[i+1]=temp; }}printf("顺序为:\n");printf("学号姓名成绩\n");for(i=0;i<6;i++)printf("%d%10.2s%10d\n",stu[a[i]].num,stu[a[i]].name,stu[a[i]].score); printf("\n");}}void shanchu() /*按姓名查找,并删除一条信息*/{ int j=0,i=0,flag=0;char a[20];printf("请输入要删除学生的姓名:");scanf("%s",&a);for(i=0;i<5;i++){ if(strcmp((stu[i].name),a)==0){ flag=i; break;;}}for(j=flag;j<5;j++){ stu[j].num=stu[j+1].num; strcpy(stu[j].name,stu[j+1].name); stu[j].score=stu[j+1].score;}printf("学号姓名成绩\n");for(i=0;i<5;i++)printf("%d%10.2s%10d\n",stu[i].num,stu[i].name,stu[i].score); }void chaxian()/* 查找并显示一条信息*/{int j=0,i=0,flag=0;char a[20];printf("请输入要查找学生的姓名:");scanf("%s",&a);for(i=0;i<5;i++){if(strcmp((stu[i].name),a)==0){ flag=i; break; }}printf("您要查找的学生信息为:\n");printf("学号姓名成绩\n");printf("%d%11.2s%11d\n",stu[i].num,stu[i].name,stu[i].score);}void g()/* 求出全班平均成绩,显示最高分最低分信息*/{ int a[5]={0,1,2,3,4};int i,j,temp;float total=0;double ave;for(i=0;i<5;i++){total=total+stu[i].score;}ave=total/5.0;printf("ave=%f\n",ave);for(j=0;j<4;j++){ for(i=0;i<4-j;i++)if(stu[a[i]].num>stu[a[i+1]].num){ temp=a[i];a[i]=a[i+1]; a[i+1]=temp; } }printf("最高成绩为:\n");printf("学号姓名成绩\n");printf("%d%11.2s%11d\n",stu[a[4]].num,stu[a[4]].name,stu[a[4]].score); printf("最低成绩为:\n");printf("学号姓名成绩\n");printf("%d%11.2s%11d\n",stu[a[0]].num,stu[a[0]].name,stu[a[0]].score); }。
学生成绩管理系统c语言源代码
学生成绩管理系统c语言源代码一、引言学生成绩管理系统是一个用于管理学生信息和成绩的软件,可以方便地查询、修改和统计学生成绩。
本文将介绍一个基于C语言的学生成绩管理系统的源代码。
二、需求分析1. 功能需求(1)学生信息管理:包括添加、删除、修改和查询学生信息;(2)成绩录入:可以录入每个学生的各科成绩;(3)成绩查询:可以按照不同的条件查询学生成绩,如按照班级、科目等;(4)成绩统计:可以对所有学生的成绩进行统计分析。
2. 性能需求(1)系统响应速度快,界面友好;(2)数据存储安全可靠,数据备份方便。
三、设计思路本系统采用C语言编写,主要采用结构体和文件读写方式实现数据存储。
具体实现过程如下:1. 定义结构体类型student存储每个学生的信息,包括姓名、性别、年龄、班级和各科成绩等。
2. 采用文件读写方式将每个学生的信息存储到文件中,并在程序启动时读取文件中的数据。
3. 实现各种功能模块,包括添加/删除/修改/查询学生信息、录入学生成绩、查询成绩和统计成绩等。
4. 对查询结果进行排序和格式化输出,方便用户查看。
四、源代码以下是基于C语言的学生成绩管理系统的源代码,包括结构体定义、文件读写、各种功能模块的实现等。
为了更好地展示代码,本文将代码分为多个模块,并加入了注释说明。
1. 结构体定义/* 定义结构体类型student,用于存储每个学生的信息 */ typedef struct student{char name[20]; // 姓名char sex[10]; // 性别int age; // 年龄char class[20]; // 班级float score[3]; // 各科成绩(数学、语文、英语)}STUDENT;2. 文件读写/* 将一个学生的信息写入文件中 */void write_student(STUDENT stu){FILE *fp;fp = fopen("student.dat", "ab");fwrite(&stu, sizeof(STUDENT), 1, fp);fclose(fp);}/* 从文件中读取所有学生的信息 */int read_student(STUDENT *stu){FILE *fp;int count = 0;fp = fopen("student.dat", "rb");if (fp == NULL) return 0;while (fread(stu, sizeof(STUDENT), 1, fp) != 0) count++;fclose(fp);return count;}3. 添加/删除/修改/查询学生信息/* 添加一个学生的信息 */void add_student(){STUDENT stu;printf("请输入学生姓名:");scanf("%s", );printf("请输入学生性别:");scanf("%s", stu.sex);printf("请输入学生年龄:");scanf("%d", &stu.age);printf("请输入学生班级:");scanf("%s", stu.class);write_student(stu); // 将该学生的信息写入文件中}/* 删除一个学生的信息 */void delete_student(){STUDENT stu;char name[20];printf("请输入要删除的学生姓名:");scanf("%s", name);FILE *fp1, *fp2;fp1 = fopen("student.dat", "rb");if (fp1 == NULL)return;fp2 = fopen("temp.dat", "wb");while (fread(&stu, sizeof(STUDENT), 1, fp1) != 0)if (strcmp(, name) != 0)fwrite(&stu, sizeof(STUDENT), 1, fp2);fclose(fp1);fclose(fp2);remove("student.dat"); // 删除原文件rename("temp.dat", "student.dat"); // 将新文件重命名为原文件}/* 修改一个学生的信息 */void modify_student(){STUDENT stu;char name[20];printf("\n请输入要修改的学生姓名:");scanf("%s", name);FILE *fp;fp = fopen("student.dat","rb+");while (fread(&stu,sizeof(STUDENT),1,fp) != 0) {if (strcmp(,name) == 0){printf("请输入修改后的学生姓名:");scanf("%s", );printf("请输入修改后的学生性别:");scanf("%s", stu.sex);printf("请输入修改后的学生年龄:");scanf("%d", &stu.age);printf("请输入修改后的学生班级:");scanf("%s", stu.class);fseek(fp,-sizeof(STUDENT),SEEK_CUR); // 将文件指针回到该记录开头fwrite(&stu, sizeof(STUDENT), 1, fp); // 写入新记录break;}}fclose(fp);}/* 查询一个学生的信息 */void query_student(){STUDENT stu;char name[20];printf("\n请输入要查询的学生姓名:");scanf("%s", name);FILE *fp;fp = fopen("student.dat","rb");while (fread(&stu,sizeof(STUDENT),1,fp) != 0)if (strcmp(,name) == 0){printf("\n姓名\t性别\t年龄\t班级\t数学成绩\t语文成绩\t 英语成绩\n");printf("%s\t%s\t%d\t%s\t%.2f\t%.2f\t%.2f\n", , stu.sex, stu.age, stu.class, stu.score[0], stu.score[1],stu.score[2]); break;}fclose(fp);}4. 录入/查询/统计成绩/* 录入学生成绩 */void input_score(){STUDENT stu;char name[20];printf("\n请输入要录入成绩的学生姓名:");scanf("%s", name);FILE *fp;fp = fopen("student.dat","rb+");while (fread(&stu,sizeof(STUDENT),1,fp) != 0)if (strcmp(,name) == 0){printf("\n请输入数学成绩:");scanf("%f", &stu.score[0]);printf("请输入语文成绩:");scanf("%f", &stu.score[1]);printf("请输入英语成绩:");scanf("%f", &stu.score[2]);fseek(fp,-sizeof(STUDENT),SEEK_CUR); // 将文件指针回到该记录开头fwrite(&stu, sizeof(STUDENT), 1, fp); // 写入新记录break;}fclose(fp);}/* 按照班级查询所有学生的成绩 */void query_score_by_class(){STUDENT stu[100];int count = read_student(stu);char class_name[20];printf("\n请输入要查询的班级名称:");scanf("%s", class_name);int i;printf("\n姓名\t性别\t年龄\t班级\t数学成绩\t语文成绩\t英语成绩\n");for (i = 0; i < count; i++)if (strcmp(stu[i].class,class_name) == 0)printf("%s\t%s\t%d\t%s\t%.2f\t%.2f\t%.2f\n", stu[i].name, stu[i].sex, stu[i].age, stu[i].class, stu[i].score[0],stu[i].score[1],stu[i].score[2]);}/* 统计所有学生的成绩 */void statistics_score(){STUDENT stu[100];int count = read_student(stu);float math_sum = 0, chinese_sum = 0, english_sum = 0;int i;for (i = 0; i < count; i++){math_sum += stu[i].score[0];chinese_sum += stu[i].score[1];english_sum += stu[i].score[2];}printf("\n数学平均分:%.2f", math_sum / count);printf("\n语文平均分:%.2f", chinese_sum / count);printf("\n英语平均分:%.2f", english_sum / count);}五、总结本文介绍了一个基于C语言的学生成绩管理系统的源代码,包括结构体定义、文件读写、各种功能模块的实现等。
c语言编写的简单的学生成绩管理系统
#include <string.h>#include <stdio.h>#include <stdlib.h>struct xuesheng{int id;char name[20];float yuwen;float shuxue;float pinjun;};typedef struct xuesheng XUE;int daxiao=sizeof(XUE);int tiqu(XUE*a){FILE *fp1;int i=0;fp1=fopen("wenjian.txt","r+");while(!feof(fp1)){if(5==fscanf(fp1,"%d%s%f%f%f",&a[i].id,a[i].name,&a[i].yuwen,&a[i].shuxue,&a[i].pinjun )){//printf("%d %s %3.2f %3.2f %3.2f\n",a[i].id,a[i].name,a[i].yuwen,a[i].shuxue,a[i].pin jun);i++;}}fclose(fp1);return i;}void xianshi(void){XUE a[100];int j=tiqu(a);int i=0;while(i<j){printf("%d %s %3.2f %3.2f %3.2f\n",a[i].id,a[i].name,a[i].yuwen,a[i].shuxue,a[i].pinju n);i++;}void paixu(void){XUE a[100];int i=tiqu(a);int j=0;int k=0;int t=0;XUE tmp;FILE*fp1;fp1=fopen("wenjian.txt","r+");printf("please input 1,according to the average score loading\nplease input2,according to the id little to big order\n");scanf("%d",&t);if(t==1){for(k=0;k<i-1;k++)for(j=k+1;j<i;j++)if(a[k].pinjun<a[j].pinjun){tmp=a[j];a[j]=a[k];a[k]=tmp;}}if(t==2){for(k=0;k<i-1;k++)for(j=k+1;j<i;j++)if(a[k].id>a[j].id){tmp=a[j];a[j]=a[k];a[k]=tmp;}}fseek(fp1,0,0);j=0;while(j<i){fprintf(fp1,"%d %s %f %f %f\n",a[j].id,a[j].name,a[j].yuwen,a[j].shuxue,a[j].pinjun); j++;}fclose(fp1);}void shanchu(void)char xinmin[20];FILE *fp1;XUE a[100];int i=tiqu(a);int j=0;int t=0;int m=0;printf("please input 1,according to name delete\nplease input 2,according to id delete\n");scanf("%d",&t);if(t==1){fp1=fopen("wenjian.txt","w+");printf("please input delete student's name:\n");scanf("%s",xinmin);for(j=0;j<i;j++)if(strcmp(a[j].name,xinmin)!=0)fprintf(fp1,"%d %s %f %f %f\n",a[j].id,a[j].name,a[j].yuwen,a[j].shuxue,a[j].pinjun); fclose(fp1);}if(t==2){fp1=fopen("wenjian.txt","w+");printf("please input delete student's id:\n");scanf("%d",&m);for(j=0;j<i;j++)if(a[j].id!=m)fprintf(fp1,"%d %s %f %f %f\n",a[j].id,a[j].name,a[j].yuwen,a[j].shuxue,a[j].pinjun); fclose(fp1);}}void charu(){FILE*fp1;XUE a;fp1=fopen("wenjian.txt","r+");fseek(fp1,0,SEEK_END);printf("please input insert student's ID name yuwen shuxue:\n");if(scanf("%d %s %f %f",&a.id,,&a.yuwen,&a.shuxue)==4){a.pinjun=(a.yuwen+a.shuxue)/2;fprintf(fp1,"%d %s %f %f %f\n",a.id,,a.yuwen,a.shuxue,a.pinjun);}fclose(fp1);}int main(int argc,char **argv){int i=0;printf("please input 1, display file informatio\n\n");printf("please input 2, delete student information\n\n");printf("please input 3, insert new student information\n\n"); printf("please input 4, information sorting\n\n");printf("please input 5, exit system\n\n");xiao:printf("please input toexecute command\n\n");scanf("%d",&i);switch(i){case 1: printf("\n");xianshi();printf("\n\n");goto xiao;case 2: printf("\n");shanchu();xianshi();printf("\n\n");goto xiao;case 3: printf("\n");charu();xianshi();printf("\n\n");goto xiao;case 4: printf("\n");paixu();xianshi();printf("\n\n");goto xiao;case 5: break;default: printf("you entered wrong order\n");goto xiao;}return 0;}。
学生成绩管理系统C语言(附完整源代码)
学生成绩管理系统C语言(附完整源代码)学生成绩管理系统C语言(附完整源代码)课程设计报告学生成绩管理系统院系:专业:班级:完成日期: 2009年1月03日设计题目:学生成绩管理系统目录1、题目描述2、算法设计/设计思想3、结构框图、各模块的功能描述4、主体思想:5、程序的,,,流程图6、源代码1.题目描述设计一个简单的学生成绩管理系统,要求有简单的界面,程序段要分清模块,该程序应该:(1)输入学生成绩,求总分,平均分,以及排序。
(2)查询学生单科成绩,总分和平均成绩;(3)添加、修改学生成绩具有下列功能:(4)实现保存与查看功能2.算法设计/设计思想利用二维数组——定义stu[][]存储学生学号、各科成绩,总分,平均分,名次,利用文件来存储,读取数据。
详细合作是::负责inputx(),print1(),input();:卖力文件的储备和读取,main(),System(),Idea()和各挪用函数之间的连;:卖力find1(),find2(),find3(),find31(),Find();:负责del(),add(),change1(),Change();前期调试由小组配合卖力。
3.结构框图、各模块的功能描述3.1建立成就表3.1.1 input()功用是输退学生的信息,便于当前的查询、欣赏。
3.2增加3.2.1 add( )功用是向inputy()增加新的内容。
3.3.2 chance( )对单科成绩进行修改。
3.3查询3.3.1可根据学号,科目,名次,进行查询。
3.3.2查询内容包孕:该学生的各课成就、、均匀分。
3.4删除3.4.1能够输退学号删除一逻辑学生的一课成就。
3.5浏览成绩单3.5.1通过此print1()可以查看所有学生的各课成绩、总分、平均分和名次。
3.6文件()3.6.1保存以上所输入的信息以达到既是关闭窗口信息也不会丢失信息的目的。
3.6.2随时打开,修改文件。
3.7.退出功用是退出主菜单退出系意见评述功能菜单统输入增加及改查找功用退出功用菜单成就功用查输排查找学学添修某某生生加改XXX某成成就绩科绩绩绩成就按按按名学科次号目查查查找找找四、主体思想:1、斟酌到此步伐量大代码多,以是用函数挪用,分几小我去完成。
学生成绩管理系统(数据结构C语言版源代码)
学生成绩管理系统(数据结构C语言版源代码)-标准化文件发布号:(9556-EUATWK-MWUB-WUNN-INNUL-DDQTY-KII#include<stdio.h>#include<string.h>#include<stdlib.h>struct students{char Num[10]; /*字符型学生学号*/char Name[20]; /*字符型学生姓名*/char Sex[3]; /*字符型学生性别*/double English; /*双精度实型英语成绩*/double Java; /*双精度实型Java成绩*/double Sjjg; /*双精度实数据结构*/double Szdl; /*双精度实型数字电路*/double Jsj; /*计算机组成原理*/struct students *next; /*用与构建连表指向下一结点*/};FILE *fp; /*定义全局变量fp*/void Revisemenu();/*修改菜单*/void Sortmenu();/*排序菜单*/void menu();/*主菜单*/void secret();/*安全验证*/struct students * Input();/*新建学生信息*/void fprint(struct students *head);/*将信息导入文件可追加*/void fprint_(struct students *head);/*将信息导入文件并覆盖*/void Browse(struct students *head);/*浏览全部学生信息*/struct students * create(struct students *head,int *n);/*从tushu_list中读取数据构建链表*/void FindofNum(struct students *head);/*按学号查询学生信息*/void FindofNname(struct students *head);/*按姓名查询学生信息*/void SortEnglish(struct students * head);/*按英语成绩排序*/void SortJava(struct students * head);/*按Java成绩排序*/void SortSjjg(struct students * head);/*按数据结构成绩排序*/void SortSzdl(struct students * head);/*按数字逻辑电路成绩排序*/void SortJsj(struct students * head);/*按计算机组成原理成绩排序*/struct students * Delete(struct students * head,char m[15]);/*按学号删除学生成绩信息*/struct students * Revise();/*修改学生信息(按编号修改)*//*主菜单*/void menu(){printf("\n\n");printf("***************************************************\n");printf(" 学生成绩管理系统 \n");printf("---------------------------------------------------\n");printf(" 1-添加新同学 2-浏览学生信息 \n");printf(" 3-按学号查询 4-按姓名查询 \n");printf(" 5-按成绩排序 6-修改学生信息 \n");printf(" 7-删除学生信息 0-退出系统 \n");printf("---------------------------------------------------\n");printf("___________________________________________________\n");}/*排序菜单*/void Sortmenu(){printf("\n\n");printf("***************************************************\n");printf(" 按成绩排序 \n");printf(" 1-大学英语 2-JAVA编程 \n");printf(" 3-数据结构 4-数字逻辑电路 \n");printf(" 5-计算机组成原理 0-返回上级菜单 \n");printf("***************************************************\n");}/*修改菜单*/void Revisemenu(){printf("\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n");printf(" 1--修改学生姓名 2--修改学生学号 \n");printf(" 3--修改学生性别 4--修改英语成绩 \n");printf(" 5--修改JAVA成绩 6--修改数据结构 \n");printf(" 7--修改数字电路 8--修改计算计 \n");printf(" 0--返回上级菜单 \n");printf("\n~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n");}/*安全验证*/void secret(){char a[20];printf("**欢迎来到学生信息管理系统,进入系统前请先进行密码验证---");printf(" ");do{gets(a); /*输入密码*/system("cls"); /*调用库函数清屏*/printf("对不起!您输入的密码有误,请重新输入---");}while(strcmp(a,"0605")!=0); /*单一密码"0605"*/system("cls");}/*新建学生信息*/struct students * Input(){struct students *p1,*p2,*head; /*建立辅助结点及头结点*/char Name;int n=0,x;printf("\n请按对应项输入学生信息以#结束:\n");printf("姓名学号性别英语 Java 数据结构数字电路计算机组成原理\n");p1=(struct students *)malloc(sizeof(struct students));head=p2=p1;do{ /*使用do while语句输入学生信息*/scanf("%s",&p1->Name);if(strcmp(p1->Name,"#")==0)break; /*判断结束符*/elsescanf("%s%s%lf%lf%lf%lf%lf",p1->Num,p1->Sex,&p1->English,&p1->Java,&p1->Sjjg,&p1->Szdl,&p1->Jsj);Name='#';p1=(struct students *)malloc(sizeof(struct students));p2->next=p1;p2=p1;n++;}while(1);p1->next=NULL;printf("学生信息输入结束!\n");getchar();printf("是否保存学生信息(1.是/2.否):");scanf("%d",&x);if(x==1)fprint(head); /*调用函数保存至文件*/elseprintf("\n文件没有被保存!\n");return head; /*返回头指针*/}/*将信息导入文件可追加*/void fprint(struct students *head){struct students *p1;if((fp=fopen("students_list.txt","a"))==NULL){printf("File open error!\n");exit(0);}for(p1=head;p1->next!=NULL;p1=p1->next) /*遍历*/fprintf(fp,"%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n", p1->Name,p1->Num,p1->Sex,p1->English,p1->Java,p1->Sjjg,p1->Szdl,p1->Jsj);/*将学生信息写入文件*/fclose(fp); /*关闭文件*/printf("\n学生信息已成功保存到文件 students_list.txt 中!\n");getchar();}/*将信息导入文件并覆盖*/void fprint_(struct students *head){struct students *p1;if((fp=fopen("students_list.txt","w"))==NULL){printf("File open error!\n");exit(0);}for(p1=head;p1!=NULL;p1=p1->next) /*遍历*/fprintf(fp,"%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n", p1->Name,p1->Num,p1->Sex,p1->English,p1->Java,p1->Sjjg,p1->Szdl,p1->Jsj);/*将学生信息写入文件*/fclose(fp); /*关闭文件*/;getchar();}/*浏览全部学生信息*/void Browse(struct students *head){char Num[10]; /*字符型学生学号*/char Name[20]; /*字符型学生姓名*/char Sex[3]; /*字符型学生性别*/double English; /*双精度实型英语成绩*/double Java; /*双精度实型Java成绩*/double Sjjg; /*双精度实数据结构*/double Szdl; /*双精度实型数字电路*/double Jsj; /*计算机组成原理*/if((fp=fopen("students_list.txt","a+"))==NULL){printf("File open error!\n");exit(0);}printf("-------------------------------------------------------------\n");printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");while(!feof(fp))/*读取并输出*/{fscanf(fp,"%s%s%s%lf%lf%lf%lf%lf",Name,Num,Sex,&English,&Java,&Sjjg,&Sz dl,&Jsj);printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",Name,Num,Sex,English,Java,Sjjg,Szdl,Jsj);};if(fclose(fp)){printf("Can not close the file!\n");exit(0);}}/*从tushu_list中读取数据构建链表*/struct students * create(struct students * head,int *n){FILE *fp;struct students*p,*p1,*p2;if((fp=fopen("students_list.txt","a+"))==NULL){printf("File open error!\n");exit(0);}while(!feof(fp)){(*n)++;p=(struct students *)malloc(sizeof(struct students));fscanf(fp,"%s%s%s%lf%lf%lf%lf%lf",p->Name,p->Num,p->Sex,&p->English,&p->Java,&p->Sjjg,&p->Szdl,&p->Jsj);if(head==NULL){head=p;p1=p;}else{p1->next=p;p2=p1;p1=p;}}p2->next=NULL;free(p);(*n)--;fclose(fp);return head;}/*按姓名查询学生信息*/void FindofName(struct students *head){int i=0,n=0;char b[20];struct students *p;head=create(head,&n);p=head;printf("\n请输入要查询的学生姓名:");scanf("%s",b);while(p!=NULL){if(strcmp(p->Name,b)==0){printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);i++;}p=p->next;}if(i==0)printf("\n对不起!没有找到名为“%s”的学生信息!\n",b);}/*按学号查询学生信息*/void FindofNum(struct students *head){int i=0,n;char b[20];struct students *p;head=create(head,&n);p=head;printf("\n请输入要查询的学生学号:");scanf("%s",b);while(p!=NULL){if(strcmp(p->Num,b)==0){printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);i++;}p=p->next;}if(i==0)printf("\n对不起!没有找到学号为“%s”学生信息!\n",b);}/*按英语成绩排序*/void SortEnglish(struct students * head){struct students *p,*tail; /*定义中间变量*/int n;double English;p=(struct students *)malloc(sizeof(struct students));head=create(head,&n);printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");while(head->next!=NULL) /*利用选择法排序*/{tail=NULL;p=head;English=p->English; /*将链表中第一个成绩赋给English*/while(p!=NULL){if((p->English)>English)/*比较*/English=p->English;tail=p;p=p->next;}tail=NULL;p=head;while(p->next!=NULL){if(p->English==English){printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);if(p==head)head=head->next;elsetail->next=p->next;}tail=p;p=p->next;}if(p->English==English){ /*分数相同时无需比较*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);tail->next=NULL;}}p=head; /*将链表赋给结构体指针*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);/*浏览排序后的信息*/printf("按英语成绩排序后输出如上(注:此过程不保存至文件):\n");return;}/*按JAVA成绩排序*/void SortJava(struct students * head){struct students *p,*tail; /*定义中间变量*/int n;double Java;p=(struct students *)malloc(sizeof(struct students));head=create(head,&n);printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");while(head->next!=NULL) /*利用选择法排序*/{tail=NULL;p=head;Java=p->Java; /*将链表中第一个成绩赋给Java*/while(p!=NULL){if((p->Java)>Java)/*比较*/Java=p->Java;tail=p;p=p->next;}tail=NULL;p=head;while(p->next!=NULL){if(p->Java==Java){printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);if(p==head)head=head->next;elsetail->next=p->next;}tail=p;p=p->next;}if(p->Java==Java){ /*成绩相同时无需比较*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);tail->next=NULL;}}p=head; /*将链表赋给结构体指针*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);/*浏览排序后的信息*/printf("按Java成绩排序后输出如上(注:此过程不保存至文件):\n");return;}/*按数据结构排序*/void SortSjjg(struct students * head){struct students *p,*tail; /*定义中间变量*/int n;double Sjjg;p=(struct students *)malloc(sizeof(struct students));head=create(head,&n);printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");while(head->next!=NULL) /*利用选择法排序*/{tail=NULL;p=head;Sjjg=p->Sjjg; /*将链表中第一个成绩赋给Sjjg*/while(p!=NULL){if((p->Sjjg)>Sjjg)/*比较*/Sjjg=p->Sjjg;tail=p;p=p->next;}tail=NULL;p=head;while(p->next!=NULL){if(p->Sjjg==Sjjg){printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);if(p==head)head=head->next;elsetail->next=p->next;}tail=p;p=p->next;}if(p->Sjjg==Sjjg){ /*成绩相同时无需比较*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);tail->next=NULL;}}p=head; /*将链表赋给结构体指针*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);/*浏览排序后的信息*/printf("按数据结构成绩排序后输出如上(注:此过程不保存至文件):\n");return;}/*按数字电路排序*/void SortSzdl(struct students * head){struct students *p,*tail; /*定义中间变量*/int n;double Szdl;p=(struct students *)malloc(sizeof(struct students));head=create(head,&n);printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");while(head->next!=NULL) /*利用选择法排序*/{tail=NULL;p=head;Szdl=p->Szdl; /*将链表中第一个成绩赋给Szdl*/while(p!=NULL){if((p->Szdl)>Szdl)/*比较*/Szdl=p->Szdl;tail=p;p=p->next;}tail=NULL;p=head;while(p->next!=NULL){if(p->Szdl==Szdl){printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);if(p==head)head=head->next;elsetail->next=p->next;}tail=p;p=p->next;}if(p->Szdl==Szdl){ /*成绩相同时无需比较*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);tail->next=NULL;}}p=head; /*将链表赋给结构体指针*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);/*浏览排序后的信息*/printf("按数字电路成绩排序后输出如上(注:此过程不保存至文件):\n");return;}/*按计算机组成原理排序*/void SortJsj(struct students * head){struct students *p,*tail; /*定义中间变量*/int n;double Jsj;p=(struct students *)malloc(sizeof(struct students));head=create(head,&n);printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");while(head->next!=NULL) /*利用选择法排序*/{tail=NULL;p=head;Jsj=p->Jsj; /*将链表中第一个成绩赋给Jsj*/while(p!=NULL){if((p->Jsj)>Jsj)/*比较*/Jsj=p->Jsj;tail=p;p=p->next;}tail=NULL;p=head;while(p->next!=NULL){if(p->Jsj==Jsj){printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);if(p==head)head=head->next;elsetail->next=p->next;}tail=p;p=p->next;}if(p->Jsj==Jsj){ /*成绩相同时无需比较*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);tail->next=NULL;}}p=head; /*将链表赋给结构体指针*/printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);/*浏览排序后的信息*/printf("按计算机组成原理成绩排序后输出如上(注:此过程不保存至文件):\n");return;}/*按学号删除学生成绩信息*/struct students * Delete(struct students * head,char m[15]){struct students *ptr1,*ptr2;int n;printf("\n所有学生信息如下:\n");Browse(head);printf("\n请输入想要删除的学生学号:");scanf("%s",m);head=create(head,&n);if(head==NULL){printf("无学生信息!\n");return head;}if((strcmp(head->Num,m)==0)&&head!=NULL){ptr2=head;head=head->next;free(ptr2);}if(strcmp(head->Num,m)!=0){ptr1=head;ptr2=head->next;while(ptr2!=NULL){if(strcmp(ptr2->Num,m)==0){ptr1->next=ptr2->next;free(ptr2);}elseptr1=ptr2;ptr2=ptr1->next;}}fprint_(head);printf("\n学号为' %s '学生信息已被删除,并保存至文件!\n",m);return head;}/*修改学生信息(按编号修改)*/struct students * Revise(){int n=0,t;char num[10];char Num[10]; /*字符型学生学号*/char Name[20]; /*字符型学生姓名*/char Sex[3]; /*字符型学生性别*/double English; /*双精度实型英语成绩*/double Java; /*双精度实型Java成绩*/double Sjjg; /*双精度实数据结构*/double Szdl; /*双精度实型数字电路*/double Jsj; /*计算机组成原理*/struct students *head=NULL;struct students *p;printf("\n所有学生信息如下:\n");Browse(head);head=create(head,&n);printf("\n输入需要修改的学生的学号:");scanf("%s",num);p=head;while(head!=NULL){if(strcmp(p->Num,num)==0){system("cls");Revisemenu();printf("编号为%s的学生信息如下:\n",num);printf("姓名学号性别英语 Java 数据结构数字电路计算机\n");printf("%s\t%s\t%s\t%.1lf\t%.1lf\t%.1lf\t%.1lf\t%.1lf\n",p->Name,p->Num,p->Sex,p->English,p->Java,p->Sjjg,p->Szdl,p->Jsj);while(1){printf("请选择需要修改的信息:");scanf("%d",&t);switch(t){case 1:printf("请输入新姓名:");scanf("%s",Name);strcpy(p->Name,Name);break;case 2:printf("请输入新学号:");scanf("%s",&Num);strcpy(p->Num,Num);break;case 3:printf("请输入新性别:");scanf("%s",Sex);strcpy(p->Sex,Sex);break;case 4:printf("请输入新英语成绩:");scanf("%lf",&English);p->English=English;break;case 5:printf("请输入新Java成绩:");scanf("%lf",&Java);p->Java=Java;break;case 6:printf("请输入新数据结构成绩:");scanf("%lf",&Sjjg);p->Sjjg=Sjjg;break;case 7:printf("请输入新数字电路成绩:");scanf("%lf",&Szdl);p->Szdl=Szdl;break;case 8:printf("请输入新计算机组成原理成绩:");scanf("%lf",&Jsj);p->Jsj=Jsj;break;case 0:system("cls");menu();goto lab;break;default:printf("对不起,输入有误!");break;}}}elsep=p->next;}lab:fprint_(head);printf("修改完成,并储存至文件!\n");return head;}/*主函数*/void main(){int choice,ch;char m[15];struct students *head=NULL;secret();menu();while(1){printf("请输入选项:");scanf("%d",&choice);switch(choice){case 1:Input();break;case 2:system("cls");menu();Browse(head);break;case 3:system("cls");menu();FindofNum(head);break;case 4:system("cls");menu();FindofName(head);break;case 5:system("cls");Sortmenu();do{printf("请输入您的选择:");scanf("%d",&ch);switch(ch){case 1:system("cls");Sortmenu();SortEnglish(head);break;case 2:system("cls");Sortmenu();SortJava(head);break;case 3:system("cls");Sortmenu();SortSjjg(head);break;case 4:system("cls");Sortmenu();SortSzdl(head);break;case 5:system("cls");Sortmenu();SortJsj(head);break;}}while(ch!=0);system("cls");menu();break;case 6:system("cls");menu();Revise();break;case 7:system("cls");menu();head=Delete(head,m);break;case 0:system("cls");printf("\t\t欢迎下次再来!");exit(0);default:printf("对不起,输入有误!");break;}}return ;}。
学生成绩管理系统c语言代码(供参考)
C程序学生管理系统以下是用c语言编写的学生成绩管理系统的简单代码,可以用vc运行(供参考)#include"stdio.h"#include"stdlib.h"#include"string.h"typedef struct student//定义学生{char name[10];int number;char sex[2];int math;int eglish;int clanguge;int average;}student;typedef struct unit//定义接点{student date;struct unit *next;}unit;unit* build()//建立链表并返回指针{unit *p;if((p=(unit*)malloc(sizeof(unit)))==NULL){ printf("=>初始化失败!");return 0;}else{p->next=NULL;p->date.number=0;//头结点存放学生人数printf("初始化成功!\n");return p;}}void add(unit *head)//增加学生{unit *p,*q;int m,n=0;q=head->next;p=(unit*)malloc(sizeof(unit));printf("=>请输入新生姓名!\n");gets(p->);fflush(stdin);printf("=>请输入学号!\n");while(n==0){scanf("%d",&m);fflush(stdin);if(q==NULL) n=1;while(q){if(q->date.number==m){printf("=>你输入的学号与已有同学的学号相同,请重新输入!\n");q=head->next;break;}else{q=q->next;if(q==NULL) n=1;}}}p->date.number=m;printf("=>请输入性别!\n");gets(p->date.sex);fflush(stdin);printf("=>请输入数学成绩\n");scanf("%d",&m);fflush(stdin);p->date.math=m;printf("=>请输入英语成绩\n");scanf("%d",&m);fflush(stdin);p->date.eglish=m;printf("=>请输入c语言成绩\n");scanf("%d",&m);fflush(stdin);p->date.clanguge=m;p->date.average=(p->date.math+p->date.eglish+p->date.clanguge);q=head->next;head->next=p;p->next=q;head->date.number++;}void deletion(unit *head)//删除一名学生{unit *p=head->next,*q=head;char N[10];printf("=>请输入你想删除的学生姓名!\n");gets(N);fflush(stdin);if(p==NULL)printf("=>系统无学生可删除!\n");while(p){if(strcmp(p->,N)==0){q->next=p->next;head->date.number--;printf("=>删除%s成功!\n",p->);free(p);break;}else{p=p->next;q=q->next;if(p==NULL)printf("=>你要删除的学生不存在,删除失败!\n");}}}int display(unit *head)//显示学生信息{unit *p=head->next;int m,n=0;char N[10];if(p==NULL){printf("=>系统无学生!\n");return 0;}while(n==0){printf("********************************************************* *********************\n");printf("=>请选择你的操作!\n");printf("=>\t\t\t1.显示所有\t2.按姓名查找\n\t\t\t3.按学号查找\t4.返回主菜单\n");scanf("%d",&m);fflush(stdin);switch(m){case 1:printf("\n=>该系统拥有%d名学生!\n\n",head->date.number);p=head->next;printf("\t姓名\t学号\t性别\t数学\t英语\tc语言\t综合\n\n");while(p){printf("\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n",p->,p->date.numb er,p->date.sex,p->date.math,p->date.eglish,p->date.clanguge,p->date.average);p=p->next;}break;case 2:printf("=>请输入查找姓名!\n");gets(N);fflush(stdin);p=head->next;while(p){if(strcmp(p->,N)==0){printf("\t姓名\t学号\t性别\t数学\t英语\tc语言\t 综合\n");printf("\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n",p->,p->date.numb er,p->date.sex,p->date.math,p->date.eglish,p->date.clanguge,p->date.average);break;}else{p=p->next;if(p==NULL)printf("=>你要查的学生不存在!");}}break;case 3: printf("=>请输入查找学号!\n");scanf("%d",&m);fflush(stdin);p=head->next;while(p){if(p->date.number==m){printf("\t姓名\t学号\t性别\t数学\t英语\tc语言\t 综合\n");printf("\t%s\t%d\t%s\t%d\t%d\t%d\t%d\n",p->,p->date.numb er,p->date.sex,p->date.math,p->date.eglish,p->date.clanguge,p->date.average);break;}else{p=p->next;if(p==NULL)printf("=>你要查的学生不存在!\n");}}break;case 4:n=1;break;}}return 1;}int range(unit *head)//排序{unit *p=head,*q=head->next;int n,i,m=head->date.number;printf("********************************************************* **********************\n");printf("\t\t\t1.按学号\t2.按成绩\n\n");printf("=>请选择操作!\n》");scanf("%d",&n);fflush(stdin);if(q==NULL){ printf("=>无学生可排序!\n");return 0;}switch(n){case 2:for(i=0;i<m;i++)//按总分排序{p=head;q=head->next;while(q->next){if((q->date.average)<(q->next->date.average)){p->next=q->next;p=p->next;q->next=p->next;p->next=q;}else{p=p->next;q=q->next;}}}break;case 1:for(i=0;i<=m;i++)//按学号排序{p=head;q=head->next;while(q->next){if((q->date.number)>(q->next->date.number)){p->next=q->next;p=p->next;q->next=p->next;p->next=q;}else{p=p->next;q=q->next;}}}break;}printf("=>排序成功!\n");return 1;}void menu(){printf("\n********************************* 主菜单***************************************\n");printf("\t\t\t1.新建系统\t2.添加学生\n\t\t\t3.删除学生\t4.查看信息\n\t\t\t5.排列顺序\t6.读取信息\n\t\t\t7.保存信息\t8.退出系统\n");printf("=>请选择你的操作!\n");}int save(unit *head)//保存{FILE *fp;unit *p;p=head;if((fp=fopen("d:\\学生","wb+"))==NULL){printf("=>保存失败!");return 0;}while(p){fwrite(&(p->date),sizeof(student),1,fp);p=p->next;}printf("=>保存成功!");fclose(fp);return 1;}unit* read()//读入系统学生信息{int i;unit *p,*q,*head;FILE *fp;if((head=(unit*)malloc(sizeof(unit)))==NULL) { printf("=>开辟空间失败!");exit(1);}else{head->next=NULL;head->date.number=0;//头结点存放学生人数}q=head;if((fp=fopen("d:\\学生","rb"))==NULL){printf("=>系统无学生!\n");return 0;}fread(&(q->date),sizeof(student),1,fp);for(i=0;i<head->date.number;i++){if((p=(unit*)malloc(sizeof(unit)))==NULL){ printf("=>读值失败!");exit(1);}fread(&(p->date),sizeof(student),1,fp);p->next=q->next;q->next=p;}fclose(fp);return head;}void main(){int m=0,n, i;unit *head;printf("************************************************************* *******************\n\n");printf("\t\t\t* 欢迎使用学生成绩管理系统 * \n");printf("\n\t\t\t\t\t\t\t\t编译员:吹吹风\n\n");printf("=>正在读取系统信息......\n");if((head=read())==0){printf("=>是否新建?\n");printf("\t\t\t是(1)\t\t否(2)\n");scanf("%d",&i);fflush(stdin);if(i==1)head=build();else if(i==2)exit(1);}elseprintf("=>信息导入成功!");while(m==0){menu();scanf("%d",&n);fflush(stdin);switch(n){case 1: head=build();break;case 2:add(head);break;case 3:deletion(head);break;case 4:display(head);break;case 5: range(head);break;case 6:head=read();if(head!=0) printf("=>读取存盘成功!\n");break;case 7:save(head);break;case 8:m=1;break;}}}。
学生录入成绩C语言代码,学生成绩管理系统C语言源代码.doc
学⽣录⼊成绩C语⾔代码,学⽣成绩管理系统C语⾔源代码.doc 学⽣成绩管理系统C语⾔源代码#include"stdio.h"#include#include#include"process.h"#include"ctype.h"typedef struct{char num[10];char name[10];int c;int math;int English;double aver;}Student;Student stu[99];int shuru(Student stud[],int n)/*输⼊若⼲条记录*/{int i=0;char sign,x[10];double a=0.0;while(sign!='n'&&sign!='N'){printf("输⼊学⽣学号:");scanf("%s",stu[n+i].num);printf("输⼊学⽣姓名:");scanf("%s",stu[n+i].name);printf("输⼊学⽣的C、数学、英语");scanf("%d%d%d",&stu[n+i].c,&stu[n+i].math,&stu[n+i].English);a=1.0*(stu[n+i].c+stu[n+i].math+stu[n+i].English/3);stu[n+i].aver=a;gets(x); /*清除多余的输⼊*/printf("是否继续输⼊?(Y/N):\n");scanf("%c",&sign);i++;}return(n+i);}void xianshi(Student stud[],int n) /*显⽰所有记录*/{int i ;printf("----------------------------------------------------------\n"); /*格式头*/printf("学号 姓名 C 数学 英语 平均成绩 \n");printf("----------------------------------------------------------\n");for(i=0;i{printf("%-10s%-10s%-10d%-10d%-10d%-10.2lf\n",stu[i].num,stu[i].name,stu[i].c,stu[i].math,stu[i].English,stu[i].aver); }}void xiugai(Student stud[],int n) /*修改*/{int i=0,choice=1;char x[10];while(choice!=0){printf("请输⼊您要修改的学⽣的学号:\n");scanf("%s",x);for(i=0;;i++){if(strcmp(stu[i].num,x)==0)break;}printf("请选择您要修改的内容:\n");printf(" ---------------------- \n");printf("| 姓名 请按 1 |\n");printf("| c 请按 2 |\n");printf("| 数学分数 请按 3 |\n");printf("| 英语分数 请按 4 |\n"); printf("| 退出 请按 0|\n"); printf("+-----。
学生成绩管理系统(c语言编写)
C程序学生管理系统/* Note:Your choice is C IDE */#include"stdio.h"#include"stdlib.h”#include”string。
h"typedef struct student//定义学生{char name[10];int number;char sex[2];int math;int eglish;int clanguge;int average;}student;typedef struct unit//定义接点{student date;struct unit *next;}unit;unit* build()//建立链表并返回指针{unit *p;if((p=(unit*)malloc(sizeof(unit)))==NULL) { printf("=>初始化失败!”);return 0;}else{p—〉next=NULL;p—>date.number=0;//头结点存放学生人数 printf(”初始化成功!\n");return p;}}void add(unit *head)//增加学生{unit *p,*q;int m,n=0;q=head—>next;p=(unit*)malloc(sizeof(unit));printf("=>请输入新生姓名!\n”);gets(p-〉date。
name);fflush(stdin);printf("=〉请输入学号!\n");while(n==0){scanf(”%d",&m);fflush(stdin);if(q==NULL) n=1;while(q){if(q—〉date。
number==m){printf(”=〉你输入的学号与已有同学的学号相同,请重新输入!\n");q=head—〉next;break;}else{q=q-〉next;if(q==NULL) n=1;}}}p—>date.number=m;printf("=>请输入性别!\n");gets(p->date。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
学生成绩管理系统实验报告一、实验内容实验名称:学生成绩管理系统实验目的:1)利用所学的三种程序基本结构以及数组、用户自定义函数进行一个简单管理系统的设计,进一步理解和掌握c语言的语法以及三种基本程序结构的综合应用。
2)通过程序中涉及的排序、查找、求和等操作加深对算法、程序设计思路、常用程序设计技巧的理解与掌握,逐步培养学生的程序开发能力。
实验的基本要求:学号(字符串)、姓名(字符串)、数学成绩(整型)、程序设计成绩(整型)。
设计程序完成以下五项功能:新建数据档案、添加数据、删除数据、对输入的数据进行排序和查询。
二、算法说明将数学成绩、程序设计成绩、姓名、学号分别设一个数组,其中姓名和学号是二维数组,其他是一维数组,并设为全局变量方便使用。
分别将各个功能以及菜单等功能设置为函数,介时调用。
主函数中运行菜单函数。
菜单函数中提供选择用switch语句调用函数。
1、新建数据build()。
用文档导入的方式导入数据。
2、添加数据add()。
界面出现相应信息并提示输入。
输入完成后用if语句选择是否再添加数据。
如果选择是则继续调用add函数,否则调用print函数继续选择其他功能。
用全局变量m来计算增加的次数。
3、删除数据rid()。
用swith语句选择是按姓名删除还是按学号删除或者返回主菜单。
按姓名则输入想要删除的对象,用for语句找到对象后,再用stremp赋值的方法将下一个信息往上一个位置移动,达到覆盖要删除的信息的效果。
最后用for循环输出。
按学号删除也是同理。
用全局变量m来计算删除的次数4、排序arrange()。
用swith语句选择是按数学成绩arr_math(),程序设计成绩arr_design()还是总分arr_total()。
按数学成绩排序时用冒泡排序的方法排列数学成绩,同时其他的姓名、学号的信息的下标也随着数学成绩的下标变动,最后用for语句一起输出。
按程序设计以及总分的具体算法也是同理。
每个程序后调用arrange()返回上级子菜单以便继续操作。
5、查询search()。
也用switch语句选择是按学号s_code()、姓名s_name()、数学成绩s_math()、程序设计成绩s_design()、总分s_total()查找。
按学号则是输入学号,用if语句查找,输出该位置所对应的成绩以及姓名。
按姓名、成绩查找也是同理。
按成绩查找时用到flag=0标记,找到至少一个flag=1输出,否则flag=0时输出不存在。
并重新调用search()函数返回上级子菜单。
6、退出。
三、程序清单#include<stdio.h>#define N 5#define M 100int i,j,m=N-1,k,choice; /*全局变量*/int math[M];int design[M];char name[50][M];char code[50][M];int total[M];void print() /*菜单函数*/{ void build();void add();void arrange();void search();void rid();printf(" 欢迎使用学生成绩管理系统!\n");printf("1.新建数据\n2.添加数据\n3.删除数据\n4.排序\n5.查询\n6.退出\n请选择:");scanf("%d",&choice);switch(choice){case 1: build();break;case 2: add();break;case 3: rid();break;case 4: arrange();break;case 5: search();break;case 6:break;}}void build() /*新建数据*/{ ;;;;np=fopen("d:code.txt","r"); /*导入文件*/for(i=0;i<N;i++)fscanf(np,"%s",code[i]);cp=fopen("d:name.txt","r");for(i=0;i<N;i++)fscanf(cp,"%s",name[i]);mp=fopen("d:math.txt","r");for(i=0;i<N;i++)fscanf(mp,"%d",&math[i]);dp=fopen("d:design.txt","r");for(i=0;i<N;i++)fscanf(dp,"%d",&design[i]);for(i=0;i<N;i++)total[i]=math[i]+design[i];char select;printf("学号姓名数学程序设计总分\n");for(i=0;i<N;i++)printf("%s %4s %4d %4d %4d\n",code[i],name[i],math[i],design[i],total[i]);printf("成功!\n");print();}void add() /*添加数据函数*/{ char select;m++;printf("请输入信息");printf("请输入学号:");scanf("%s",code[m]);printf("请输入姓名:");scanf("%s",name[m]);printf("请输入数学成绩:");scanf("%d",&math[m]);printf("请输入程序设计成绩:");scanf("%d",&design[m]);total[m]=math[m]+design[m];for(i=0;i<=m;i++)printf("%s %s %d %d %d\n",code[i],name[i],math[i],design[i],total[i]);printf("是否继续Y/N?");getchar();scanf("%c",&select);if(select=='y'||select=='Y') add();else print();}void name_rid() /*按名字删除函数*/{ void rid();m--;char name2[10],select;printf("输入您要删除姓名:");scanf("%s",name2);for(i=0;i<=m+1;i++)if(strcmp(name2,name[i])==0){ for(j=i;j<=m;j++){strcpy(code[j],code[j+1]);strcpy(name[j],name[j+1]);math[j]=math[j+1];design[j]=design[j+1];}}for(i=0;i<=m;i++)printf("%s %s %4d %4d %4d \n",code[i],name[i],math[i],design[i],total[i]); printf("是否继续Y/N?");getchar();scanf("%c",&select);if(select=='y'||select=='Y') name_rid();else rid();}void code_rid() /*按学号删除函数*/{ void rid();m--;char NO[10];int select;printf("输入您要删除的学号:");scanf("%s",&NO);for(i=0;i<=m+1;i++)if(strcmp(NO,code[i])==0){ for(j=i;j<=m;j++){ strcpy(code[j],code[j+1]);strcpy(name[j],name[j+1]);math[j]=math[j+1];design[j]=design[j+1];}}for(i=0;i<=m;i++)printf("%s %s %4d %4d %4d \n",code[i],name[i],math[i],design[i],total[i]); printf("是否继续Y/N?");getchar();scanf("%c",&select);if(select=='y'||select=='Y') code_rid();else rid();}void rid() /*删除数据总函数*/{int select;printf("1.按姓名\n2.按学号\n3.返回主菜单\n请选择:");scanf("%d",&select);switch(select){case 1: name_rid();break;case 2:code_rid();break;case 3:print(); break;default:break;}}void arr_math() /*按数学成绩排序函数*/{ void arrange();int temp1;char str1[100],str2[100];for(j=0;j<=m-1;j++)for(i=0;i<=m-1-j;i++)if(math[i]<math[i+1]){temp1=math[i];math[i]=math[i+1];math[i+1]=temp1;strcpy(str1,name[i]);strcpy(name[i],name[i+1]);strcpy(name[i+1],str1);strcpy(str2,code[i]);strcpy(code[i],code[i+1]);strcpy(code[i+1],str2);}printf("按数学成绩排序\n");for(i=0;i<=m;i++)printf("%s %s %4d\n",code[i],name[i],math[i]); arrange();}void arr_design() /*按程序设计成绩排序*/{ void arrange();int temp1;char str1[100],str2[100];for(j=0;j<=m-1;j++)for(i=0;i<=m-1-j;i++)if(design[i]<design[i+1]){temp1=design[i];design[i]=design[i+1];design[i+1]=temp1;strcpy(str1,name[i]);strcpy(name[i],name[i+1]);strcpy(name[i+1],str1);strcpy(str2,code[i]);strcpy(code[i],code[i+1]);strcpy(code[i+1],str2);}printf("按程序设计成绩排序\n");for(i=0;i<=m;i++)printf("%s %s %4d\n",code[i],name[i],design[i]); arrange();}void arr_total() /*按总分排序*/{ void arrange();int temp1;char str1[100],str2[100];for(j=0;j<=m;j++)for(i=0;i<=m-1-j;i++)if(total[i]<total[i+1]){temp1=total[i];total[i]=total[i+1];total[i+1]=temp1;strcpy(str2,code[i]);strcpy(code[i],code[i+1]);strcpy(code[i+1],str2);strcpy(str1,name[i]);strcpy(name[i],name[i+1]);strcpy(name[i+1],str1);}printf("总分排序/n");for(i=0;i<=m;i++)printf("%s %s %4d\n",code[i],name[i],total[i]);arrange();}void arrange() /*排序的总函数*/{int select;printf("1.数学成绩排序\n2.程序设计成绩排序\n3.总分排序\n4.返回主菜单\n"); scanf("%d",&select);switch(select){case 1:arr_math();break;case 2:arr_design();break;case 3:arr_total();break;case 4:print();break;}}void s_code() /*按学号查找函数*/{ void search();char NO[10];int flag=0;printf("请输入学号:");scanf("%s",NO);for(i=0;i<=m;i++)if(strcmp(NO,code[i])==0){flag=1;printf("%s %s %4d %4d %4d\n",code[i],name[i],math[i],design[i],total[i]);} if(flag==0) {printf("不存在\n欢迎继续使用!\n");search();}else {printf("欢迎继续使用!\n");search();}}void s_name() /*按姓名查找函数*/{ void search();char name2[10];int flag=0;printf("请输入姓名:");scanf("%s",name2);for(i=0;i<=m;i++)if(strcmp(name2,name[i])==0){flag=1;printf("%s %s %4d %4d %4d\n",code[i],name[i],math[i],design[i],total[i]);} if(flag==1) {printf("欢迎继续使用!\n");search();}else { printf("不存在\n欢迎继续使用!\n");search();}}void s_math() /*按数学成绩查找*/{ void search();int mark,flag=0;printf("请输入数学成绩:");scanf("%d",&mark);for(i=0;i<=m;i++)if(mark<=math[i]){ flag=1;printf("%s %s %4d %4d %4d\n",code[i],name[i],math[i],design[i],total[i]);}search();if(flag==0) { printf("不存在\n欢迎继续使用!\n");search();}}void s_design() /*按程序设计成绩查找*/{ void search();int mark,flag=0;printf("请输入程序设计成绩:");scanf("%d",&mark);for(i=0;i<=m;i++)if(mark<=design[i]){ flag=1;printf("%s %s %4d %4d %4d\n",code[i],name[i],math[i],design[i],total[i]);}search();if(flag==0) { printf("不存在\n欢迎继续使用!\n");search();}}void s_total() /*按总分查找*/{ void search();int mark,flag=0;printf("请输入总分:");scanf("%d",&mark);for(i=0;i<=m;i++)if(mark<=total[i]){ flag=1;printf("%s %s %4d %4d %4d\n",code[i],name[i],math[i],design[i],total[i]); }search();if(flag==0) {printf("不存在\n欢迎继续使用!\n");search();}}void search() /*查找总函数*/{int select;printf("1.学号查询\n2.姓名查询\n3.数学成绩查询\n4.程序设计成绩查询\n5.总分查询\n6.返回主菜单\n");scanf("%d",&select);switch(select){case 1:s_code();break;case 2:s_name();break;case 3:s_math();break;case 4:s_design();break;case 5:s_total();break;case 6:print();break;}}void main() /*主函数*/{ print();}四、运行结果运行界面,显示“欢迎您使用学生成绩管理系统”,并提供菜单,供选择。