结构体实现学生成绩管理系统,要求在图片,学习遇到问题,thanks!

img

img


c语言结构体实现学生成绩管理系统 学生学号姓名性别语文成绩 平均分
功能:从键盘输入,建表输出,输出信息包括结构体所有内容以及每门功课的平均分;按学号姓名平均成绩排序,姓名查找,修改条目,删除条目,新增条目,统计不及格人数,统计各分数段人数

提供参考类似实例,期望对你编写代码有所帮助:https://blog.csdn.net/weixin_43887148/article/details/116887706?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522166981461516782428655114%2522%252C%2522scm%2522%253A%252220140713.130102334..%2522%257D&request_id=166981461516782428655114&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~top_positive~default-2-116887706-null-null.142^v67^control,201^v3^add_ask,213^v2^t3_esquery_v3&utm_term=%E5%AD%A6%E7%94%9F%E6%88%90%E7%BB%A9%E7%AE%A1%E7%90%86%E7%B3%BB%E7%BB%9F&spm=1018.2226.3001.4187

img

参考代码如下,有帮助的话采纳一下哦!:

#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
需要修改的话可以找我

img

#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;
}

网上搜一下,有很相似的啊。如果单独写,悬赏得加几倍......

这种提网上答案一大把不是