参考代码如下,有帮助的话采纳一下哦!:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct student{
int num;
char gender[32];
char name[64];
int chi;
int mat;
int eng;
int avr;
}S;
void stu_add(S *p);
void stu_delete(S *p);
void stu_search(S *p);
void stu_modify(S *p);
void stu_show(S *p);
void stu_chi(S *p);
void stu_mat(S *p);
void stu_eng(S *p);
void stu_avr(S *p);
int cnt=0;
int main(int argc, const char *argv[])
{
S stu[20];
int key;
while(1){
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("---------9.按平均成绩降序排名---------\n");
printf("-------------10.退出系统---------------\n");
printf("---------------选择操作---------------\n");
scanf("%d",&key);
switch(key){
case 1:
stu_add(stu);
break;
case 2:
stu_delete(stu);
break;
case 3:
stu_search(stu);
break;
case 4:
stu_modify(stu);
break;
case 5:
stu_show(stu);
break;
case 6:
stu_chi(stu);
break;
case 7:
stu_mat(stu);
break;
case 8:
stu_eng(stu);
break;
case 9:
stu_eng(stu);
break;
case 10:
printf("---------------------结束---------------------\n");
return -1;
default:
printf("ERROR\n");
}
}
return 0;
}
void stu_add(S *p){
int i,jud;
while(1){
printf("请输入--->学号 性别 姓名 语文成绩 数学成绩 英语成绩\n");
scanf("%d %s %s %d %d %d",&p[cnt].num,p[cnt].gender,p[cnt].name,\
&p[cnt].chi,&p[cnt].mat,&p[cnt].eng);
p[cnt].avr=(p[cnt].chi+p[cnt].mat+p[cnt].eng)/3;
cnt++;
printf("是否继续添加 \"1\"是 \"0\"否\n");
scanf("%d",&jud);
if(jud==0)
break;
}
}
void stu_delete(S *p){
int num=0;
printf("输入被删除学生学号:");
scanf("%d",&num);
int i=0,j=0;
S t1;
for(i=0;i<cnt;i++){
if(p[i].num==num){
for(j=i;j<cnt;j++){
t1=p[j];
p[j]=p[j+1];
p[j+1]=t1;
}
cnt--;
}
}
}
void stu_search(S *p){
int num;
printf("输入该学生学号:");
scanf("%d",&num);
int i;
for(i=0;i<cnt;i++){
if(p[i].num==num){
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
}
}
}
void stu_modify(S *p){
int num;
printf("输入该学生学号:");
scanf("%d",&num);
int i;
for(i=0;i<cnt;i++){
if(p[i].num==num){
printf("请输入--->学号 性别 姓名 语文成绩 数学成绩 英语成绩\n");
scanf("%d %s %s %d %d %d",&p[i].num,p[i].gender,p[i].name,\
&p[i].chi,&p[i].mat,&p[i].eng);
printf("该学生信息已被修改为:\n");
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
break;
}
}
}
void stu_show(S *p){
int i;
for(i=0;i<cnt;i++){
printf("--------------------录入显示---------------------\n");
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
}
}
void stu_chi(S *p){
int i,j;
S t;
for(i=0;i<cnt-1;i++){
for(j=0;j<cnt-1-i;j++){
if(p[j].chi<p[j+1].chi){
t=p[j];
p[j]=p[j+1];
p[j+1]=t;
}
}
}
for(i=0;i<cnt;i++){
printf("---------------按语文成绩降序显示---------------\n");
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
}
}
void stu_mat(S *p){
int i,j;
S t;
for(i=0;i<cnt-1;i++){
for(j=0;j<cnt-1-i;j++){
if(p[j].mat<p[j+1].mat){
t=p[j];
p[j]=p[j+1];
p[j+1]=t;
}
}
}
for(i=0;i<cnt;i++){
printf("---------------按数学成绩降序显示---------------\n");
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
}
}
void stu_eng(S *p){
int i,j;
S t;
for(i=0;i<cnt-1;i++){
for(j=0;j<cnt-1-i;j++){
if(p[j].eng<p[j+1].eng){
t=p[j];
p[j]=p[j+1];
p[j+1]=t;
}
}
}
for(i=0;i<cnt;i++){
printf("---------------按英语成绩降序显示---------------\n");
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
}
}
void stu_avr(S *p){
int i,j;
S t;
for(i=0;i<cnt-1;i++){
for(j=0;j<cnt-1-i;j++){
if(p[j].avr<p[j+1].avr){
t=p[j];
p[j]=p[j+1];
p[j+1]=t;
}
}
}
for(i=0;i<cnt;i++){
printf("---------------按平均成绩降序显示---------------\n");
printf("学号:%-7d 性别:%-7s 姓名:%-7s 语文成绩:%-7d 数学成绩:%-7d 英语成绩:%-7d 平均成绩:%-7d\n",p[i].num,p[i].gender,p[i].name,p[i].chi,p[i].mat,p[i].eng,p[i].avr);
}
}
学生成绩管理系统(C语言实现)
https://blog.csdn.net/qq_64314976/article/details/125904800
可以看看我之前写的https://blog.csdn.net/weixin_44882124/article/details/125285056
需要修改的话可以找我
#include<stdio.h>
#include<windows.h>
#define Max 25
#define obj_num 5
struct Stu
{
char Name[25]; //姓名
int Number; //学号
int Language_score;//语文成绩
int Math_score; //数学成绩
int English_score; //英语成绩
int PE_score; //体育成绩
int C_score; //C语言成绩
int Sum_score; //总成绩
};
void input(struct Stu Class[],int j)
{
printf("输入第%d位同学姓名:",j+1);
scanf("%s",Class[j].Name);
getchar();
printf("输入第%d位同学学号:",j+1);
scanf("%d",&Class[j].Number);
printf("输入第%d位同学语文成绩:",j+1);
scanf("%d",&Class[j].Language_score);
printf("输入第%d位同学数学成绩:",j+1);
scanf("%d",&Class[j].Math_score);
printf("输入第%d位同学英语成绩:",j+1);
scanf("%d",&Class[j].English_score);
printf("输入第%d位同学体育成绩:",j+1);
scanf("%d",&Class[j].PE_score);
printf("输入第%d位同学C语言成绩:",j+1);
scanf("%d",&Class[j].C_score);
Class[j].Sum_score=Class[j].Language_score+Class[j].Math_score+Class[j].English_score+Class[j].PE_score+Class[j].C_score;
}
void output(struct Stu Class[],int n)
{
printf("---------------------------------------------\n");
printf("姓名 学号 语文 数学 英语 体育 C语言 总分");
printf("\n");
int j;
for(j=0; j<n; j++)
{
printf("%5s",Class[j].Name);
printf("%5d",Class[j].Number);
printf("%6d",Class[j].Language_score);
printf("%6d",Class[j].Math_score);
printf("%6d",Class[j].English_score);
printf("%6d",Class[j].PE_score);
printf("%6d",Class[j].C_score);
printf("%7d",Class[j].Sum_score);
printf("\n");
}
printf("---------------------------------------------\n");
}
void outputOne(struct Stu Class[],int j)
{
printf("姓名 学号 语文 数学 英语 体育 C语言 总分");
printf("\n");
printf("%5s",Class[j].Name);
printf("%5d",Class[j].Number);
printf("%6d",Class[j].Language_score);
printf("%6d",Class[j].Math_score);
printf("%6d",Class[j].English_score);
printf("%6d",Class[j].PE_score);
printf("%6d",Class[j].C_score);
printf("%7d",Class[j].Sum_score);
printf("\n");
}
void Sort(struct Stu Class[],int n)
{
int j,k;
struct Stu t;
for(j=0; j<n-1; j++)
{
for(k=0; k<n-j-1; k++)
{
if(Class[k].Sum_score<Class[k+1].Sum_score)
{
t=Class[k];
Class[k]=Class[k+1];
Class[k+1]=t;
}
}
}
}
int search(int number,int n,struct Stu Class[])
{
int i,p=0;
for(i=0; i<n; i++)
{
if(Class[i].Number==number)
{
p=i;
return p;
}
}
return -1;
}
void modify(int number,int n,struct Stu Class[])
{
int index=search(number,n,Class);
if(index==-1)
{
printf("找不到该学号\n");
}
else
{
printf("学号%d的学生是第%d位\n",number,index+1);
input(Class,index);
printf("修改成功\n");
output(Class,n);
}
}
void del(int number,int n,struct Stu Class[])
{
int index=search(number,n,Class);
if(index==-1)
{
printf("找不到该学号\n");
}
else
{
printf("学号%d的学生是第%d位\n",number,index);
int i;
for(i=index; i<n-1; i++)
{
Class[i]= Class[i+1];
}
printf("删除成功\n");
output(Class,n-1);
}
}
double calave(int n,struct Stu Class[],double ave[])
{
int Language_score_sum=0;
int Math_score_sum=0;
int English_score_sum=0;
int PE_score_sum=0;
int C_score_sum=0;
for(int i=0; i<n; i++)
{
Language_score_sum+=Class[i].Language_score;
Math_score_sum+=Class[i].Math_score;
English_score_sum+=Class[i].English_score;
PE_score_sum+=Class[i].PE_score;
C_score_sum+=Class[i].C_score;
}
ave[0]=(double)Language_score_sum/n;
ave[1]=(double)Math_score_sum/n;
ave[2]=(double)English_score_sum/n;
ave[3]=(double)PE_score_sum/n;
ave[4]=(double)C_score_sum/n;
}
void save(int n,struct Stu Class[])
{
FILE *fp;
fp = fopen("score_data.txt","w");
if(fp == NULL)
{
printf("error!");
return;
}
else
{
for(int j=0; j<n; j++)
{
fprintf(fp,"%s %d %d %d %d %d %d %d\n",Class[j].Name,Class[j].Number,Class[j].Language_score,Class[j].Math_score,Class[j].English_score,Class[j].PE_score,Class[j].C_score,Class[j].Sum_score);
}
printf("文件写入成功\n");
}
fclose(fp);
}
int read(int n,struct Stu Class[])
{
FILE *fp;
fp = fopen("score_data.txt","r");
int count=0;
if(fp == NULL)
{
printf("error!");
return 0;
}
else
{
for(int j=0; j<n; j++)
{
int flag=fscanf(fp,"%s %d %d %d %d %d %d %d\n",Class[j].Name,&Class[j].Number,&Class[j].Language_score,&Class[j].Math_score,&Class[j].English_score,&Class[j].PE_score,&Class[j].C_score,&Class[j].Sum_score);
if(flag!=-1) count++;
}
printf("文件读取成功\n");
}
fclose(fp);
return count;
}
void menu(struct Stu Class[])
{
int n=0,count;
int option=1;
while(option<=9&&option>=1)
{
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("------9.保存至文件------\n");
printf("------other.退出 ------\n");
printf("------------------------\n");
printf("输入选项:");
scanf("%d",&option);
switch(option)
{
case 1:
{
system("cls");
printf("输入学生的个数(不大于%d):",Max-n);
scanf("%d",&count);
while(count--)
{
input(Class,n++);
}
output(Class,n);
break;
}
case 2:
{
system("cls");
output(Class,n);
break;
}
case 3:
{
system("cls");
Sort(Class,n);
output(Class,n);
break;
}
case 4:
{
system("cls");
int number;
printf("输入要查找的学号:");
scanf("%d",&number);
int index=search(number,n,Class);
if(index==-1)
{
printf("查找失败\n");
}
else
{
printf("查找成功\n");
outputOne(Class,index);
}
break;
}
case 5:
{
system("cls");
output(Class,n);
int number;
printf("输入要修改成绩的学生对应的学号:");
scanf("%d",&number);
modify(number,n,Class);
output(Class,n);
break;
}
case 6:
{
system("cls");
output(Class,n);
int number;
printf("输入要删除的学号:");
scanf("%d",&number);
del(number,n,Class);
n--;
system("cls");
output(Class,n);
break;
}
case 7:
{
system("cls");
output(Class,n);
double ave[obj_num];
calave(n,Class,ave);
char str[]="平均分";
printf("\n");
printf("%5s",str);
printf(" ");
printf("%5.2lf",ave[0]);
printf("%6.2lf",ave[1]);
printf("%6.2lf",ave[2]);
printf("%6.2lf",ave[3]);
printf("%6.2lf",ave[4]);
printf("\n");
break;
}
case 8:
{
system("cls");
n-=n;
n+=read(Max,Class);
break;
}
case 9:
{
system("cls");
save(n,Class);
break;
}
default :
{
break;
}
}
}
}
int main()
{
struct Stu Class [Max];
menu(Class);
return 0;
}
网上搜一下,有很相似的啊。如果单独写,悬赏得加几倍......
这种提网上答案一大把不是