c语言大作业 学生成绩管理系统
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c语言大作业 学生成绩管理系统相关的知识,希望对你有一定的参考价值。
给个参考你:/*编制一个学生成绩管理系统,每个学生信息包括:学号、姓名、C语言、高数和英语成绩。具体功能:
(1)创建信息链表并以磁盘文件保存;
(2)读取磁盘文件并显示输出所有学生的成绩;
(3)按学号或姓名查询成绩;
(4)添加成绩记录;
(5)修改指定姓名或学号的学生的成绩并可存盘;
(6)显示输出60分以下、60~79、80~89、90分以上各分数段的学生信息。以C语言成绩为例*/
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <string.h>
#define N 20
typedef struct
char name[10];
int num;
float c;
float math;
float english;
float aver;
stu;
//菜单
void menu() /*便于操作员使用*/
/*清屏*/
system("cls");
printf(" 学生平时成绩管理\n");
printf("=======================\n");
printf(" 1.成绩录入\n");
printf(" 2.计算\n");
printf(" 3.查询\n");
printf(" 4.修改\n");
printf(" 5.插入\n");
printf(" 6.显示\n");
printf(" 7.统计\n");
printf(" 8.删除\n");
printf(" 0.退出\n");
printf("=======================\n");
printf("请选择相应的功能:");
//成绩录入
void input()
FILE *fp;
stu xs; /*定义一个结构体变量来装从文件中读出来的数据*/
if((fp=fopen("student.dat","ab"))==NULL) printf("can't open file!\n");exit(0);
printf("\n录入格式: 姓名 学号 C语言 高数 英语 当输入姓名为ps结束录入\n");
while(1) /*中间加油break,可使循环中断*/
scanf("%s",xs.name);
if(strcmp(xs.name,"ps")==0) break;/*判断姓名是否为ps,用字符串判断*/
scanf("%d%f%f%f",&xs.num,&xs.c,&xs.math,&xs.english);
xs.aver=0;/*给平均分变量赋初值*/
fwrite(&xs,sizeof(stu),1,fp); //将成绩信息写入文件
fclose(fp);
//计算平均分
void sum()
int i=0,n;
stu xs[N];
FILE *fp;
if((fp=fopen("student.dat","rb+"))==NULL) printf("can't open file!\n");exit(0);
while(!feof(fp))/*文件读入内存,读取指针未到文件尾时返回值为0,读到尾时返回值为1,加!取反后,结束即为0*/
fread(&xs[i],sizeof(stu),1,fp);/*读入结构体变量*/
if(feof(fp)) break;/*上面while循环那个会多读一次因为读到尾时那个0还没返回,这里判断如果以读到文件尾,则直接停止,避免重复输入*/
xs[i].aver=(xs[i].c+xs[i].math+xs[i].english)/3;
i++;
n=i;/*把i的末尾值给n,用于下面循环写入*/
i=0;
fclose(fp);
if((fp=fopen("student.dat","wb"))==NULL) printf("can't open file!\n");exit(0);
while(i<n)
fwrite(&xs[i],sizeof(stu),1,fp);
i++;
fclose(fp);
void xingming()
FILE *fp;
stu xs;
char name[10];
printf("\n输入要查学生的姓名: ");scanf("%s",name);
if((fp=fopen("student.dat","rb"))==NULL) printf("can't open file!\n");exit(0);
while(!feof(fp))
fread(&xs,sizeof(stu),1,fp);
if(strcmp(xs.name,name)==0)/*按姓名查询时判断输入的姓名是否存在,会循环从数据中找取*/
printf(" 学生的信息如下:\n");
printf("\n%10s %6s %6s %6s %6s %6s\n","姓名","学号","C语言","高数"," 英语","平均成绩");
printf("%10s %6d %6.2f %6.2f %6.2f %6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
break;
if(feof(fp)) printf("查找失败!!!"); /*学生不存在*/
fclose(fp);
void xuehao()
FILE *fp;
stu xs;
int num;
printf("\n输入要查学生的学号: ");scanf("%d",&num);
if((fp=fopen("student.dat","rb"))==NULL) printf("can't open file!\n");exit(0);
while(!feof(fp))
fread(&xs,sizeof(stu),1,fp);
if(xs.num==num)/*按学号查询时判断输入的学号是否存在,会循环从数据中找取*/
printf(" 学生的信息如下:\n");
printf("\n%10s %6s %6s %6s %6s %6s\n","姓名","学号","C语言","高数"," 英语","平均成绩");
printf("%10s %6d %6.2f %6.2f %6.2f %6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
break;
if(feof(fp)) printf("查找失败!!!");
fclose(fp);
//查询
void search()
char ch1;
system("cls");
printf("请输入按何种方式查询:\n");
printf("1-姓名,2-学号:");
ch1=getchar();/*用字符接收*/
switch(ch1)/*判断*/
case '1':xingming();break;
case '2':xuehao();break;
getch();/*让屏幕停留同时按任意键返回*/
//修改:输入学生的姓名,查找该学生,若找到则修改该生的成绩信息,并显示修改前后的结果;
void modi()
stu xs;
FILE *fp;
char name[10];
system("cls");
printf("\n输入要查学生的姓名: ");scanf("%s",name);
if((fp=fopen("student.dat","rb+"))==NULL) printf("can't open file!\n");exit(0);
while(!feof(fp))
fread(&xs,sizeof(stu),1,fp);
if(strcmp(xs.name,name)==0)/*判断输入要修改的姓名是否存在*/
printf(" 修改前学生的信息如下:\n");
printf("\n%10s %6s %6s %6s %6s %6s\n","姓名","学号","C语言","高数"," 英语","平均成绩");
printf("%10s %6d %6.2f %6.2f %6.2f %6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
printf("\n请输入该生的C语言成绩:");scanf("%f",&xs.c);
printf("\n高数成绩:");scanf("%f",&xs.math);
printf("\n英语成绩:");scanf("%f",&xs.english);
xs.aver=(xs.c+xs.math+xs.english)/3;
break;
if(!feof(fp))
printf(" \n 修改后的学生的信息如下:\n");
printf("\n%10s %6s %6s %6s %6s %6s\n","姓名","学号","C语言","高数"," 英语","平均成绩");
printf("%10s %6d %6.2f %6.2f %6.2f %6.2f\n",xs.name,xs.num,xs.c,xs.math,xs.english,xs.aver);
fseek(fp,sizeof(-stu),1);/*负号表示后退,1表示文件当前位置*/
fwrite(&xs,sizeof(stu),1,fp);/*再写入,同时把要修改的那个覆盖掉*/
else
printf("\n学生不存在,修改失败!!");
fclose(fp);
getch();
//插入:输入学生的平时的各项成绩,插入到指定位置;当指定的位置超出范围时,将其插入到全班的最后,并显示插入成功后的结果。
void insert()
int i=0,j,k,lenth;
FILE *fp;
stu s,xs[N];
system("cls");
printf("\n请输入插入的学生的姓名:");scanf("%s",&s.name);
printf("\n学生的学号:");scanf("%d",&s.num);
printf("\n学生的C成绩:");scanf("%f",&s.c);
printf("\n高数成绩:");scanf("%f",&s.math);
printf("\n英语成绩:");scanf("%f",&s.english);
s.aver=(s.c+s.math+s.english)/3;
printf("\n插入位置:");scanf("%d",&k);
// i=0;
if((fp=fopen("student.dat","rb"))==NULL) printf("can't open file!\n");exit(0);
while(!feof(fp))
fread(&xs[i],sizeof(stu),1,fp);/*把数据读入到结构体数组中*/
if(feof(fp)) break;
i++;
fclose(fp);
lenth=i;
if(k<lenth && k>=0)/*k的位置要位于数组范围之内*/
//插入
for(j=lenth-1;j>=k;j--)
xs[j+1]=xs[j];/*一开始j是最大的,往后移一个这样移动避免数据被覆盖*/
/*循环是只循环这一句的*/
xs[k]=s;/*将输入的学生信息加入这个k位置*/
lenth++;/*长度+1*/
//写回
if((fp=fopen("student.dat","wb"))==NULL) printf("不能建立文件!!\n");exit(0);
for(i=0;i<lenth;i++)
fwrite(&xs[i],sizeof(stu),1,fp);
else/*不再数组范围之内*/
if((fp=fopen("student.dat","ab"))==NULL) printf("不能建立文件!!\n");exit(0);
fwrite(&s,sizeof(stu),1,fp);
fclose(fp);
//显示
void print()
FILE *fp;
stu s;
system("cls");
if((fp=fopen("student.dat","rb"))==NULL) printf("can't open file!\n");exit(0);
printf("\n%10s %s %6s %6s %6s %6s\n","姓名","学号","C语言","高数"," 英语","平均成绩");
while(!feof(fp))
fread(&s,sizeof(stu),1,fp);//从文件中读取成绩信息
if(feof(fp)) break;//判断是否文件尾
printf("%10s %6d %6.2f %6.2f %6.2f %6.2f\n",s.name,s.num,s.c,s.math,s.english,s.aver);
fclose(fp);
getch();
//统计
void tongji()
int i=0,j=0,k=0,l=0,m=0,n,p,q,r,t,u;
FILE *fp;
stu s[N], *p1[N],*p2[N],*p3[N],*p4[N];/*用指针数组*/
system("cls");
if((fp=fopen("student.dat","rb"))==NULL) printf("cant't open file!\n");exit(0);
while(!feof(fp))
fread(&s[i++],sizeof(stu),1,fp);/*读入数据*/
if(feof(fp)) break;
t=i;i=0;
for(u=0;u<t;u++)/*以下每个指针数组用于指向各分数段的学生信息*/
if(s[i].c<60) p1[j++]=&s[i++];continue;/*每个学生信息只能位于一个分数段*/
if(s[i].c>=60&&s[i].c<80) p2[k++]=&s[i++];continue;
if(s[i].c>=80&&s[i].c<90) p3[l++]=&s[i++];continue;
if(s[i].c>=90) p4[m++]=&s[i++];continue;
printf("不及格:姓名 学号 C语言\n");
for(n=0;n<j-1;n++)
printf("%10s %6d %6.2f\n",p1[n]->name,p1[n]->num,p1[n]->c);
printf("60-79:姓名 学号 C语言\n");
for(p=0;p<k;p++)
printf("%10s %6d %6.2f\n",p2[p]->name,p2[p]->num,p2[p]->c);
printf("80-89:姓名 学号 C语言\n");
for(q=0;q<l;q++)
printf("%10s %6d %6.2f\n",p3[q]->name,p3[q]->num,p3[q]->c);
printf("90以上:姓名 学号 C语言\n");
for(r=0;r<m;r++)
printf("%10s %6d %6.2f\n",p4[r]->name,p4[r]->num,p4[r]->c);
fclose(fp);
getch();
//删除:输入学生姓名,若该学生存在,则删除,并显示删除后余下的学生成绩信息
void dele()
stu xs[N];
FILE *fp;
char name[10];
int i=0,len,k=-1/*k<0是为后面if判断用的*/;
system("cls");
printf("\n输入要删除的学生姓名: ");scanf("%s",name);
if((fp=fopen("student.dat","rb+"))==NULL) printf("can't open file!\n");exit(0);
while(!feof(fp))
fread(&xs[i],sizeof(stu),1,fp);
if(feof(fp)) break;
if(strcmp(xs[i].name,name)==0) k=i;
i++;
fclose(fp);
//以下是删除后重新写文件
len=i;/*结构体数组上限*/
if(k>=0)/*k>0说明找到删除学生位置*/
if((fp=fopen("student.dat","wb+"))==NULL) printf("can't open file!\n");exit(0);
for(i=0;i<len;i++)
if(i==k) continue;/*从这个位置开始写入*/
fwrite(&xs[i],sizeof(stu),1,fp);
fclose(fp);
else printf("删除失败!!!\n");getch(); /*失败后重新返回菜单*/
print();
//菜单选择
void main()
char ch;
while(1)
menu();// 显示菜单
ch=getch();//选择菜单
if(ch=='0') break;
switch(ch)//判断功能项
case '1':input();break;
case '2':sum();break;
case '3':search();break;
case '4':modi();break;
case '5':insert();break;
case '6':print( );break;
case '7':tongji();break;
case '8':dele();break;
printf("\n欢迎使用!!!\n");
参考技术A #include<stdio.h>
#include<windows.h>
#include<string.h>
#include<stdlib.h>
void caidan();
void denglu()
//定义用户名数组为char类型
char mz[20];
//定义密码数组为char类型
char mima[20];
//定义学员初始值为0
int count=0;
do
//清空屏幕
system("cls");
printf("\t\t\t\t学员管理系统平台\n");
printf("=============================================================================\n");
printf("\t\t【用户登陆】\n");
printf("\t\t\t\t用户名:");
fflush(stdin);
//存储用户名
scanf("%s",mz);
printf("\t\t\t\t密码:");
fflush(stdin);
//存储密码
scanf("%s",mima);
//如果输入正确,执行菜单功能
if(strcmp(mz,"kkk")==0&&strcmp(mima,"ok")==0)
caidan();
break;
//如果输不正确,提示登录失败
else
printf("登陆失败\n");
count++;
system("pause");
system("cls");
//超过三次退出程序
if(count>=3)
printf("登陆失败,请稍后再试\n");
exit(5);
while(1);
struct student
int num;
char name[20];
int fs[3];
int zf;
stu[50];
//定义登录函数
void danlu(student *p)
printf("输入学号:");
scanf("%d",&p->num);
printf("输入姓名:");
fflush(stdin);
scanf("%s",&p->name);
fflush(stdin);
p->zf=0;
//循环输入三门成绩
for(int i=0;i<3;i++)
printf("输入第%d门成绩",i+1);
scanf("%d",&p->fs[i]);
p->zf=p->zf+p->fs[i];
//定义录入函数
int luru(student *p,int n)
//int j=0;
do
printf("输入第%d个学员的学号:",n+1);
scanf("%d",&(p+n)->num);
fflush(stdin);
printf("输入第%d个学员的姓名:",n+1);
scanf("%s",&(p+n)->name);
fflush(stdin);
(p+n)->zf=0;
for(int i=0;i<3;i++)
printf("输入第%d个学员第%d门成绩",n+1,i+1);
scanf("%d",&(p+n)->fs[i]);
(p+n)->zf=(p+n)->zf+(p+n)->fs[i];
n++;
printf("继续请按y键");
fflush(stdin);
//如果输入的不是‘y’,就退出
if(getchar()!='y')
break;
else
continue;
while(1);
return n;
//定义排序函数
void paixu(student stu[],int h)
//定义一个student类型的结构tt
student tt;
for(int i=0;i<h;i++)
for(int j=0;j<h-i;j++)
if(stu[j].zf<stu[j+1].zf)
tt=stu[j];
stu[j]=stu[j+1];
stu[j+1]=tt;
//定义插入函数
void charu(student stu[],int t,student s)
int i=0;
for( i=0;i<t;i++)
if(stu[i].zf>s.zf)
break;
for(int j=t-1;j>=i;j--)
stu[j+1] = stu[j];
stu[i]=s;
int cha(student stu[],int n)
//定义变量保存要插入学员的信息
student s;
do
//录入单个学员信息
danlu(&s);
//把学员信息插入到数组中
charu(stu,n,s);
//学员的总数要加1
n++;
printf("是否继续插入(y/n):");
fflush(stdin);
if(getchar()!='y')
break;
while(1);
return n;
void shucu(student stu[],int k)
printf("-----------学员信息如下---------\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
for(int i=0;i<k;i++)
printf("%d\t%s\t%d\t%d\t%d\t%d\n",stu[i].num,stu[i].name,stu[i].fs[0],stu[i].fs[1],stu[i].fs[2],stu[i].zf);
int shancu(student stu[],int n)
int i,xuehao;
printf("输入要删除的学号:");
scanf("%d",&xuehao);
for(i=0;i<n;i++)
if(xuehao==stu[i].num)
break;
for(int j = i;j<=n-2;j++)
stu[j] = stu[j+1];
return n-1;
void chazao(student stu[],int d)
int xuehao,i;
printf("输入要查找的学号");
scanf("%d",&xuehao);
for(i=0;i<d;i++)
if(xuehao==stu[i].num)
break;
printf("-----------该学员信息如下---------\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
printf("%d\t%s\t%d\t%d\t%d\t%d\n",stu[i].num,stu[i].name,stu[i].fs[0],stu[i].fs[1],stu[i].fs[2],stu[i].zf);
void baocun(student stu[],int n)
FILE *fp;
fp=fopen("E:\\studentbin.txt","wb");
fwrite(stu,sizeof(struct student),n,fp);
fclose(fp);
printf("保存成功!\n");
void read(student stu[])
FILE *fp;
int a=0;
fp=fopen("E:\\studentbin.txt","rb");
a=fread(stu,sizeof(struct student),100,fp);
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
for(int i=0;i<a;i++)
printf("%d\t%s\t%d\t%d\t%d\t%d\n",stu[i].num,stu[i].name,stu[i].fs[0],stu[i].fs[1],stu[i].fs[2],stu[i].zf);
fclose(fp);
void caidan()
int i;
student stu[50];
int count=0,s=0;
do
system("cls");
printf("\t\t\t\t请选择要进行功能菜单:\n");
printf("\t\t\t\t----------------------\n");
printf("\t\t\t\t1.录入单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t2.显示所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t3.排序显示所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t4.插入单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t5.删除单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t6.查找单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t7.读取所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t8.保存所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t9.退出系统。\n");
printf("\t\t\t\t----------------------\n");
scanf("%d",&i);
switch(i)
case 1:
//录入学员
system("cls");
count = luru(stu,count);
system("pause");
break;
case 2:
//输出学员信息
system("cls");
shucu(stu,count);
system("pause");
break;
case 3:
//排序
system("cls");
paixu(stu,count);
shucu(stu,count);
system("pause");
break;
case 4:
//插入学员信息
system("cls");
count = cha(stu,count);
paixu(stu,count);
shucu(stu,count);
system("pause");
break;
case 5:
//删除学员信息
system("cls");
count = shancu(stu,count);
shucu(stu,count);
system("pause");
break;
case 6:
system("cls");
chazao(stu,count);
system("pause");
break;
case 7:
system("cls");
read(stu);
system("pause");
break;
case 8:
system("cls");
baocun(stu,count);
system("pause");
break;
case 9:
exit(8);
while('0');
void main()
int m,w,n;
struct student stu[50];
denglu();
caidan();
本回答被提问者和网友采纳 参考技术B #include<stdio.h>
#include<windows.h>
#include<string.h>
#include<stdlib.h>
void caidan();
void denglu()
//定义用户名数组为char类型
char mz[20];
//定义密码数组为char类型
char mima[20];
//定义学员初始值为0
int count=0;
do
//清空屏幕
system("cls");
printf("\t\t\t\t学员管理系统平台\n");
printf("=============================================================================\n");
printf("\t\t【用户登陆】\n");
printf("\t\t\t\t用户名:");
fflush(stdin);
//存储用户名
scanf("%s",mz);
printf("\t\t\t\t密码:");
fflush(stdin);
//存储密码
scanf("%s",mima);
//如果输入正确,执行菜单功能
if(strcmp(mz,"kkk")==0&&strcmp(mima,"ok")==0)
caidan();
break;
//如果输不正确,提示登录失败
else
printf("登陆失败\n");
count++;
system("pause");
system("cls");
//超过三次退出程序
if(count>=3)
printf("登陆失败,请稍后再试\n");
exit(5);
while(1);
struct student
int num;
char name[20];
int fs[3];
int zf;
stu[50];
//定义登录函数
void danlu(student *p)
printf("输入学号:");
scanf("%d",&p->num);
printf("输入姓名:");
fflush(stdin);
scanf("%s",&p->name);
fflush(stdin);
p->zf=0;
//循环输入三门成绩
for(int i=0;i<3;i++)
printf("输入第%d门成绩",i+1);
scanf("%d",&p->fs[i]);
p->zf=p->zf+p->fs[i];
//定义录入函数
int luru(student *p,int n)
//int j=0;
do
printf("输入第%d个学员的学号:",n+1);
scanf("%d",&(p+n)->num);
fflush(stdin);
printf("输入第%d个学员的姓名:",n+1);
scanf("%s",&(p+n)->name);
fflush(stdin);
(p+n)->zf=0;
for(int i=0;i<3;i++)
printf("输入第%d个学员第%d门成绩",n+1,i+1);
scanf("%d",&(p+n)->fs[i]);
(p+n)->zf=(p+n)->zf+(p+n)->fs[i];
n++;
printf("继续请按y键");
fflush(stdin);
//如果输入的不是‘y’,就退出
if(getchar()!='y')
break;
else
continue;
while(1);
return n;
//定义排序函数
void paixu(student stu[],int h)
//定义一个student类型的结构tt
student tt;
for(int i=0;i<h;i++)
for(int j=0;j<h-i;j++)
if(stu[j].zf<stu[j+1].zf)
tt=stu[j];
stu[j]=stu[j+1];
stu[j+1]=tt;
//定义插入函数
void charu(student stu[],int t,student s)
int i=0;
for( i=0;i<t;i++)
if(stu[i].zf>s.zf)
break;
for(int j=t-1;j>=i;j--)
stu[j+1] = stu[j];
stu[i]=s;
int cha(student stu[],int n)
//定义变量保存要插入学员的信息
student s;
do
//录入单个学员信息
danlu(&s);
//把学员信息插入到数组中
charu(stu,n,s);
//学员的总数要加1
n++;
printf("是否继续插入(y/n):");
fflush(stdin);
if(getchar()!='y')
break;
while(1);
return n;
void shucu(student stu[],int k)
printf("-----------学员信息如下---------\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
for(int i=0;i<k;i++)
printf("%d\t%s\t%d\t%d\t%d\t%d\n",stu[i].num,stu[i].name,stu[i].fs[0],stu[i].fs[1],stu[i].fs[2],stu[i].zf);
int shancu(student stu[],int n)
int i,xuehao;
printf("输入要删除的学号:");
scanf("%d",&xuehao);
for(i=0;i<n;i++)
if(xuehao==stu[i].num)
break;
for(int j = i;j<=n-2;j++)
stu[j] = stu[j+1];
return n-1;
void chazao(student stu[],int d)
int xuehao,i;
printf("输入要查找的学号");
scanf("%d",&xuehao);
for(i=0;i<d;i++)
if(xuehao==stu[i].num)
break;
printf("-----------该学员信息如下---------\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
printf("%d\t%s\t%d\t%d\t%d\t%d\n",stu[i].num,stu[i].name,stu[i].fs[0],stu[i].fs[1],stu[i].fs[2],stu[i].zf);
void baocun(student stu[],int n)
FILE *fp;
fp=fopen("E:\\studentbin.txt","wb");
fwrite(stu,sizeof(struct student),n,fp);
fclose(fp);
printf("保存成功!\n");
void read(student stu[])
FILE *fp;
int a=0;
fp=fopen("E:\\studentbin.txt","rb");
a=fread(stu,sizeof(struct student),100,fp);
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
for(int i=0;i<a;i++)
printf("%d\t%s\t%d\t%d\t%d\t%d\n",stu[i].num,stu[i].name,stu[i].fs[0],stu[i].fs[1],stu[i].fs[2],stu[i].zf);
fclose(fp);
void caidan()
int i;
student stu[50];
int count=0,s=0;
do
system("cls");
printf("\t\t\t\t请选择要进行功能菜单:\n");
printf("\t\t\t\t----------------------\n");
printf("\t\t\t\t1.录入单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t2.显示所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t3.排序显示所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t4.插入单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t5.删除单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t6.查找单个学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t7.读取所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t8.保存所有学员信息。\n");
printf("\t\t\t\t----------------------\n");
Sleep(100);
printf("\t\t\t\t9.退出系统。\n");
printf("\t\t\t\t----------------------\n");
scanf("%d",&i);
switch(i)
case 1:
//录入学员
system("cls");
count = luru(stu,count);
system("pause");
break;
case 2:
//输出学员信息
system("cls");
shucu(stu,count);
system("pause");
break;
case 3:
//排序
system("cls");
paixu(stu,count);
shucu(stu,count);
system("pause");
break;
case 4:
//插入学员信息
system("cls");
count = cha(stu,count);
paixu(stu,count);
shucu(stu,count);
system("pause");
break;
case 5:
//删除学员信息
system("cls");
count = shancu(stu,count);
shucu(stu,count);
system("pause");
break;
case 6:
system("cls");
chazao(stu,count);
system("pause");
break;
case 7:
system("cls");
read(stu);
system("pause");
break;
case 8:
system("cls");
baocun(stu,count);
system("pause");
break;
case 9:
exit(8);
while('0');
void main()
int m,w,n;
struct student stu[50];
denglu();
caidan();
参考技术C #include<stdio.h>
#define N 10
int input(struct Stud st[]);
void display(struct Stud st[],int n);
void maxmin(struct Stud st[],int n,int *ax,int *);
struct Stud
int no;
char name[10];
int degree;
;
void main()
int n,max,min;
struct Stud st[N];
n=input(st);
printf(" 显示结果如下:\n");
display(st,n);
maxmin(st,n,max,min);
printf(" 最高分:\n");
printf("\t%d\t%s\t%d\n",st[min].no,st[max].name,st[max].degree);
printf(" 最低分:\n");
printf("\t%d\t%s\t%d\n",st[min].no,st[min].name,st[min].degree);
int input(struct Stud st[])
int n,i;
printf("学生人数:");
scanf("%d",&n);
for(i=0;i<n;i++)
printf(" 第%d个学生:",i+1);
scanf("%d%s%d",&st[i].no,st[i].name,st[i].degree);
return n;
void display(struct Stud st[],int n)
int i;
printf("\t学号\t姓名\t分数\n");
for(i=0;i<n;i++)
printf("\t%d\t%s\t%d\n",st[i].no,st[i].name,st[i].degree);
void masmin(struct Stud st[],int n, int *max,int *min)
int i;
max=min=0;
for(i=1;i<n;i++)
if(st[max].degree<st[i].degree)
max=i;
if(st[min].degree>st[i].degree)
min=i;
是不是这样的?追问
1、信息录入:录入学生成绩信息(包括学生学号、姓名、各门课程的成绩等);
2、信息查询:输入学号,查询学生各门课程的成绩,并显示。
3、排序:按各门课程的成绩平均分进行排序,并显示。
4、信息删除与修改——输入学号,删除该学生的成绩信息。
要有这些功能的。。
哦,天哪!哪种程序要打半天,对不起哈,我没那么多时间
C语言编程题目,关于学生成绩管理系统的。向各位求助了
#include<stdio.h>#include<string.h>
#include <malloc.h>
#include <stdlib.h>
#include<conio.h>
#define LEN sizeof(struct student)
typedef struct student
long numb;
int chinese;
int math;
int english;
int totalscore;
char name[12];
struct student *next;
STU;
//声明部分
STU* creat();
void output(STU *head);
STU* creatByN(int num);
STU* findByNumb(STU *head, long num);
STU* findByNumbEx(STU *head, long num, STU **ppBefore);
STU* findByName(STU *head, char *name);
void find(STU *head);
STU* del(STU *head);
STU* insert(STU *head);
void update(STU *head);
STU* sort(STU *head);
void save_info(STU *head);
STU *load_info();
void Backup_info(STU *head);
int n;//全局变量
void main()
STU *head;
int choice;
for(;;)
system("cls");/*清屏*/
printf("\t欢迎使用成绩管理系统\t\n");
printf("\t1:输入多个学生信息\t\n");
printf("\t2:显示全部学生信息\t\n");
printf("\t3:删除\t\n");
printf("\t4:查找\t\n");
printf("\t5:插入\t\n");
printf("\t6:修改\t\n");
printf("\t7:排序\t\n");
printf("\t8:保存到文件\t\n");
printf("\t9:从文件加载\t\n");
printf("\t10:备份\t\n");
printf("\t0:退出\t\n");
printf("*请输入数字(0-9)进行功能选择 :");
scanf("%d",&choice);
if(choice==0) break;
switch(choice)
case 1: head=creat(); break;
case 2: output(head); break;
case 3: head=del(head); break;
case 4: find(head); break;
case 5: head=insert(head); break;
case 6: update(head); break;
case 7: head=sort(head);break;
case 8: save_info(head); break;
case 9: head=load_info(); break;
case 10:Backup_info(head);break;
printf("按任意键继续....\n");
getch();/*暂停*/
printf("欢迎使用,再见!\n");
STU *creat()/*创建链表*/
STU *head,*pnew,*ptail;
head=NULL;
n=0;//初始化
printf("现在进行学生信息的输入,学号输入为0时结束\n");
while(1)
//不断申请新节点
pnew=(STU *)malloc(LEN);
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
scanf("%ld",&pnew->numb);
if(pnew->numb==0)
break;
scanf("%s",pnew->name);
scanf("%d%d%d",&pnew->chinese,&pnew->math,&pnew->english);
pnew->totalscore=0; pnew->totalscore=pnew->chinese+pnew->math+pnew->english;
pnew->next=NULL;//将节点连接到链表尾部
n++;
if(n==1)
head=pnew;
ptail=pnew;
else
ptail->next=pnew;
ptail=pnew;
//这个算法的思路是让pnew指向新开辟的结点,ptail指向链表中最后一个结点,把pnew所指的结点连接在ptail所指的结点后面,用"ptail->next=pnew"来实现.
return head;//因为可能对head进行赋值,所以有返回值
void output(STU *head)
STU *p;//定义一个可动指针,使其不断下移完成多个输出
printf("当前共有%d个节点:\n",n);
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
for(p=head;p!=NULL;p=p->next)
printf("%ld\t%s\t%d\t%d\t%d\t%d\n",p->numb,p->name,p->chinese,p->math,p->english,p->totalscore);
//无变动不返回
struct student *creatByN(int num)
STU *head,*pnew,*ptail;
int i;
//链表初始化
head=NULL;
n=0;
//链表创建,一个循环
for(i=0;i<num;i++)
//获得一个节点,并赋值,节点由pnew指向
pnew=(STU *)malloc(LEN);
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
scanf("%ld",&pnew->numb);
scanf("%s",pnew->name);
scanf("%d%d%d",&pnew->chinese,&pnew->math,&pnew->english);
pnew->next=NULL;//将pnew所指向的节点,插入到链表尾部
n++;
if(n==1)
head=pnew;
ptail=pnew;
else
ptail->next=pnew;
ptail=pnew;
return head;
STU* findByNumb(STU *head, long num)
STU *p,*presult;
presult=NULL;
for(p=head;p!=NULL;p=p->next)
if(p->numb==num)
presult=p;//记录此时指针的位置
break;
return presult;
STU* findByName(STU *head, char *name)
STU *p,*presult;
presult=NULL;
for(p=head;p!=NULL;p=p->next)
if(strcmp(p->name,name)==0)
presult=p;
break;
return presult;//位置变更有返回值
STU* findByNumbEx(STU *head, long num, STU **ppBefore)
STU *p,*presult,*pBefore;
presult=pBefore=NULL;
for(p=head;p!=NULL;pBefore=p,p=p->next)//记录指针的前一个位置
if(p->numb==num)
presult=p;
break;
*ppBefore=pBefore;
return presult;
void find(STU *head)
int num,choice;
STU *pr;
char name[12];
printf("输入要查找的方式(1:按学号,2:按姓名):");
scanf("%d",&choice);
if(choice==1)
printf("输入要查找的学号:");
scanf("%ld",&num);
pr=findByNumb(head,num);
else if(choice==2)
printf("输入要查找的姓名:");
scanf("%s",name);
pr=findByName(head,name);
if(pr==NULL)
printf("对不起,查无此人\n");
else
printf("找到了,该生信息如下:\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
printf("%ld\t%s\t%d\t%d\t%d\n",pr->numb,pr->name,pr->chinese,pr->math,pr->english,pr->totalscore);
void update(STU *head)
int num;
STU *pr;
printf("输入要查找的学号:");
scanf("%ld",&num);
pr=findByNumb(head,num);
if(pr==NULL)
printf("对不起,查无此人\n");
else
printf("找到了,该生信息如下:\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
printf("%ld\t%s\t%d\t%d\t%d\n",pr->numb,pr->name,pr->chinese,pr->math,pr->english);
printf("请输入修改信息\n");
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
scanf("%ld%s%d%d%d%d",&pr->numb,&pr->name,&pr->chinese,&pr->math,&pr->english);
pr->totalscore=0; pr->totalscore=pr->chinese+pr->math+pr->english;
STU* del(STU *head)
long num;
STU *pCur,*pBefore;
//查找要删除的节点,用pCur记录该节点
printf("输入要删除的学号:");
scanf("%ld",&num);
pCur=findByNumbEx(head,num,&pBefore);
//如果该节点存在,进行删除
if(pCur!=NULL)
n--;//记录删除后节点个数
//根据pCur所指节点位置进行判断:头节点或后续节点
//删除的是头节点
if(pCur==head)
head=pCur->next;
//删除的是后续节点
else
//获取前向节点指针pBefore
//利用pBefore和pCur完成删除
pBefore->next=pCur->next;
return head;
STU* insert(STU *head)
STU *pCur,*pnew,*pBefore,*p;
//申请一个新节点,并赋值
pnew=(STU *)malloc(LEN);
printf("学号\t姓名\t语文\t数学\t英语\t总分\n");
scanf("%d",&pnew->numb);
scanf("%s",&pnew->name);
scanf("%d%d%d",&pnew->chinese,&pnew->math,&pnew->english);
pnew->totalscore=0; pnew->totalscore=pnew->chinese+pnew->math+pnew->english;
pnew->next=NULL;
if(head==NULL)//链表为空
head=pnew;
else//链表不为空
//找位置,即获取pCur
for(p=head;p!=NULL;pBefore=p,p=p->next)
if(p->numb > pnew->numb)
pCur=p;
break;
//没有找到pCur,则应将pnew插入到尾节点之后
if(p==NULL)
pBefore->next=pnew;
//找到pCur,则应将pnew插入到pCur之前,根据pCur的位置分为:头结点之前和中间节点之前两种情况
else
//pCur是头结点
if(pCur==head)
pnew->next=pCur;
head=pnew;
//pCur是中间结点
else
pnew->next=pCur;
pBefore->next=pnew;
n++;
return head;
STU* sort(STU *head)
STU *first; /*排列后有序链的表头指针*/
STU *tail; /*排列后有序链的表尾指针*/
STU *p_min; /*保留键值更小的节点的前驱节点的指针*/
STU *min; /*存储最小节点*/
STU *p; /*当前比较的节点*/
(STU *)malloc(LEN);
first = NULL;
while (head != NULL) /*在链表中找键值最小的节点。*/
/*注意:这里for语句就是体现选择排序思想的地方*/
for (p=head,min=head; p->next!=NULL; p=p->next) /*循环遍历链表中的节点,找出此时最小的节点。*/
if (p->next->totalscore < min->totalscore) /*找到一个比当前min小的节点。*/
p_min = p; /*保存找到节点的前驱节点:显然p->next的前驱节点是p。*/
min = p->next; /*保存键值更小的节点。*/
/*上面for语句结束后,就要做两件事;一是把它放入有序链表中;二是根据相应的条件判断,安排它离开原来的链表。*/
/*第一件事*/
if (first == NULL) /*如果有序链表目前还是一个空链表*/
first = min; /*第一次找到键值最小的节点。*/
tail = min; /*注意:尾指针让它指向最后的一个节点。*/
else /*有序链表中已经有节点*/
tail->next = min; /*把刚找到的最小节点放到最后,即让尾指针的next指向它。*/
tail = min; /*尾指针也要指向它。*/
/*第二件事*/
if (min == head) /*如果找到的最小节点就是第一个节点*/
head = head->next; /*显然让head指向原head->next,即第二个节点,就OK*/
else /*如果不是第一个节点*/
p_min->next = min->next; /*前次最小节点的next指向当前min的next,这样就让min离开了原链表。*/
if (first != NULL) /*循环结束得到有序链表first*/
tail->next = NULL; /*单向链表的最后一个节点的next应该指向NULL*/
head = first;
return head;
//保存
void save_info(STU *head)
STU *p;
FILE *fp;
char filename[20];
printf("输入保存文件的文件名:");
scanf("%s",filename);
if((fp=fopen(filename,"w"))==NULL)
printf("can not open the file");
exit(0);
fprintf(fp,"当前共有%d个节点:\n",n);
fprintf(fp,"学号\t姓名\t语文\t数学\t英语\t总分\n");
for(p=head;p!=NULL;p=p->next)
fprintf(fp,"%ld\t%s\t%d\t%d\t%d%\t%d\n",p->numb,p->name,p->chinese,p->math,p->english,p->totalscore);
fclose(fp);
printf("保存成功!\n");
//加载
STU *load_info()
STU *head,*pnew,*ptail;
FILE *fp;
char filename[20],secondLine[20];
int num,i;
printf("输入读取文件的文件名:");
scanf("%s",filename);
if((fp=fopen(filename,"r"))==NULL)
printf("can not open the file");
exit(0);
fscanf(fp,"当前共有%d个节点:",&num);
//过滤第二行
for(i=0;i<6;i++)
fscanf(fp,"%s",secondLine);
//链表初始化
head=NULL;
n=0;
//链表创建,一个循环
for(i=0;i<num;i++)
//获得一个节点,并赋值,节点由pnew指向
pnew=(STU *)malloc(LEN);
fscanf(fp,"%ld%s%d%d%d%d",&pnew->numb,&pnew->name,&pnew->chinese,&pnew->math,&pnew->english,&pnew->totalscore);
pnew->next=NULL;
//将pnew所指向的节点,插入到链表尾部
n++;//记录加载后节点个数
if(n==1)
head=pnew;
ptail=pnew;
else
ptail->next=pnew;
ptail=pnew;
fclose(fp);
printf("读取成功!\n");
return head;
void Backup_info(STU *head)//备份
FILE *in,*out;
char infile[10],outfile[10];
printf("Enter the inflie name:\n");
scanf("%s",infile);
printf("Enter the outflie name:\n");
scanf("%s",outfile);
if((in=fopen(infile,"r"))==NULL)
printf("cannot open infile\n");
exit(0);
if((out=fopen(outfile,"w"))==NULL)
printf("cannot open outfile\n");
exit(0);
while(! feof(in)) fputc(fgetc(in),out);
fclose(in);
fclose(out);
printf("备份成功!\n"); 参考技术A 定义一个结构体,结构体成员为学生的学号、姓名、各科成绩。然后在主函数里申请一个结构体数组的动态内存 因为不超过三十人 你就申请三十个就行了。然后就是写那几个函数了 第一个要传结构体数组的指针进去 因为要对值进行修改 剩下几个传值就行了 思路就是这样 我也没动手试过 不过应该差不多 你要是嫌传指针什么的麻烦 把结构体数组设为全局变量也行。
以上是关于c语言大作业 学生成绩管理系统的主要内容,如果未能解决你的问题,请参考以下文章