include<stdio.h>

include<stdlib.h>

include<string.h>

include<ctype.h>

struct Student #自定义结构体 { int number; char name[10]; int phy; int math; int eng; int com; }stu[40];

int choose_carte() #菜单显示 { int c; do{ system("cls"); printf("\t\t请选择该学生成绩统计系统所实现功能\n"); printf("\t\t1.录入:输入学生数据 \n"); printf("\t\t2.显示:显示学生数据 \n"); printf("\t\t3.统计:统计最高分,最低分 \n"); printf("\t\t0.退出 \n"); printf("\t\t**************************************************\n"); printf("\t\t\tGive you Choice(0-3):"); scanf("%d",&c); }while(c<0||c>3); return c; }

int Intput(struct Student stu[],int n) #输入学生信息 { int i=0; char c; do { printf("\t\t\t学号:"); scanf("\t\t\t%d",&stu[n+i].number); printf("\t\t\t姓名:"); scanf("\t\t\t%s",&stu[n+i].name); printf("\t\t\t物理分数:"); scanf("\t\t\t%d",&stu[n+i].phy); printf("\t\t\t数学分数:"); scanf("\t\t\t%d",&stu[n+i].math); printf("\t\t\t外语分数:"); scanf("\t\t\t%d",&stu[n+i].eng); printf("\t\t\t计算机分数:"); scanf("\t\t\t%d",&stu[n+i].com); i++; printf("\t\t\t您还要继续录入成绩吗?\n"); printf("\t\t\t请输入‘y’继续,或'n'停止"); scanf("\t\t\t%c",&c); }while(c=='y'); return (i+n); }

int Output(struct Student stu[],int n) #输出学生信息 { int i; printf("\t\t----------------------------------------------------\n"); printf("\t\t| Number | Name | Phy | Math | Eng | Com | \n"); printf("\t\t----------------------------------------------------\n"); for( i=1;i<n+1;i++) { printf("\t\t%4d%10s%9d%9d%9d%9d\n",stu[i-1].number,stu[i-1].name,stu[i-1].phy,stu[i-1].math,stu[i-1].eng,stu[i-1].com); printf("\t\t----------------------------------------------------\n"); } system("pause");

}

void Data(struct Student stu[],int n) #统计 { int i; int sum=0; int phy_hight=0; int math_hight=0; int eng_hight=0; int com_hight=0; int phy_low=0; int math_low=0; int eng_low=0; int com_low=0; for(i=0;i<n;i++) { if(stu[phy_hight].phy<stu[i].phy) phy_hight=i; if(stu[phy_low].phy>stu[i].phy) phy_low=i; if(stu[i].phy<60) printf("\t\t物理不及格的%4d%10s%9d\n",stu[i].number,stu[i].name,stu[i].phy);

if(stu[math_hight].math<stu[i].math)
        math_hight=i;
    if(stu[math_low].math>stu[i].math)
        math_low=i;
       if(stu[i].math<60)
        printf("\t\t数学不及格的%4d%10s%9d\n",stu[i].number,stu[i].name,stu[i].math);

    if(stu[eng_hight].eng<stu[i].eng)
        eng_hight=i;
    if(stu[eng_low].eng>stu[i].eng)
        eng_low=i;
        if(stu[i].eng<60)
        printf("\t\t英语不及格的%4d%10s%9d\n",stu[i].number,stu[i].name,stu[i].eng);

    if(stu[com_hight].com<stu[i].com)
        com_hight=i;
    if(stu[com_low].com>stu[i].com)
        com_low=i;
        if(stu[i].phy<60)
       printf("\t\t计算机不及格的%4d%10s%9d\n",stu[i].number,stu[i].name,stu[i].com);
        ++sum;
    }
printf("\t\t该数据中不及格的人数为%d\n",sum);
system("pause");
printf("\t\t物理最高分为:\n");
printf("\t\t%4d%10s%9d\n",stu[phy_hight].number,stu[phy_hight].name,stu[phy_hight].phy);
printf("\t\t数学最高分为:\n");
printf("\t\t%4d%10s%9d\n",stu[math_hight].number,stu[math_hight].name,stu[math_hight].math);
printf("\t\t外语最高分为:\n");
printf("\t\t%4d%10s%9d\n",stu[eng_hight].number,stu[eng_hight].name,stu[eng_hight].eng);
printf("\t\t计算机最高分为:\n");
printf("\t\t%4d%10s%9d",stu[com_hight].number,stu[com_hight].name,stu[com_hight].com);
printf("\n\n\n");

printf("\t\t物理最低分为:\n");
printf("\t\t%4d%10s%9d\n",stu[phy_low].number,stu[phy_low].name,stu[phy_low].phy);
printf("\t\t数学最低分低为:\n");
printf("\t\t%4d%10s%9d\n",stu[math_low].number,stu[math_low].name,stu[math_low].math);
printf("\t\t外语最低分为:\n");
printf("\t\t%4d%10s%9d\n",stu[eng_low].number,stu[eng_low].name,stu[eng_low].eng);
printf("\t\t计算机最低分为:\n");
printf("\t\t%4d%10s%9d\n",stu[com_low].number,stu[com_low].name,stu[com_low].com);
system("pause");

}

void main() { int n=0; do{ switch(choose_carte()) { case 0: break; case 1: printf("\t\t\t请输入学生的个人信息\n"); n=Intput(stu,n); break; case 2: printf("\t\t\t输出所有学生的个人信息\n"); Output(stu,n); break; case 3: Data(stu,n); break; }

}while(choose_carte()!=0); }

3 comments

  • @ 2024-5-22 20:19:45

    大哥 你私信徐聪明就行了

    • @ 2024-5-21 22:14:25

      为什么第二个也不对

      • @ 2024-5-21 22:14:08
        #include <stdio.h>
        #include <string.h>
        struct Student    //同前
        {
            char num[13];
            char name[10];
            int c;
            int math;
            int english;
            int grade;
            double average;
        };
        void calculate(struct Student s[],int n);  //计算总分和均分,数据在s数组中,共有n个元素
        void sort1(struct Student [],int);      //按总分降序排序
        void sort2(struct Student [],int);      //按学号升序排序
        void output(struct Student [],int);     //输出成绩单
        void outputExcellent(struct Student [],int);  //输出优秀者:总分超285,单科不低于90
        int main()
        {
            struct Student stu[]= {{"201152501104","Tom",65,69 ,68 },
                {"201152501114","Jeery",94 ,89 ,63 },
                {"201152501138","Speike",67 ,62 ,84 },
                {"201152501204","Tyke",100 ,95 ,91 },
                {"201152501202","Tuffy",59 ,80 ,55 },
                {"201152501115","Butch",100 ,99 ,89 },
                {"201152501201","Lightning",95 ,92 ,99 },
                {"201152501145","Topsy",88 ,56 ,67 },
                {"201152501203","Droopy",62 ,62 ,95 },
                {"201152501140","Drupa",80 ,60 ,86 },
                {"201152501205","Buzz",73 ,90 ,94}
            };
            int stuNum=sizeof(stu)/sizeof(stu[0]);  //用sizeof运算确定数组中元素个数
            //计算总分和均分后输出
            calculate(stu,stuNum);
            printf("下面是成绩单:\n");
            output(stu,stuNum);
            printf("优秀者名单:\n");
            outputExcellent(stu,stuNum);
            //按总分降序排序后输出
            sort1(stu,stuNum);
            printf("按总分降序排序后:\n");
            output(stu,stuNum);
            //按学号升序排序后输出
            sort2(stu,stuNum);
            printf("按学号升序排序后:\n");
            output(stu,stuNum);
            return 0;
        }
        
        void calculate(struct Student s[],int n)  //计算总分和均分
        {
            int i;
            for(i=0; i<n; i++)
            {
                s[i].grade=s[i].c+s[i].math+s[i].english;
                s[i].average=s[i].grade/3.0;
            }
            return;
        }
        
        void sort1(struct Student s[],int n)   //按总分降序排序
        {
            int i,j;
            struct Student t;
            for(j=0; j<n-2; j++)
            {
                for(i=0; i<n-j-1; i++)
                    if (s[i].grade<s[i+1].grade)
                    {
                        t=s[i];  //交换结构体
                        s[i]=s[i+1];
                        s[i+1]=t;
                    }
            }
            return;
        }
        void sort2(struct Student s[],int n)   //按学号升序排序
        {
            int i,j;
            struct Student t;
            for(j=0; j<n-2; j++)
            {
                for(i=0; i<n-j-1; i++)
                    if (strcmp(s[i].num,s[i+1].num)>0)
                    {
                        t=s[i];
                        s[i]=s[i+1];
                        s[i+1]=t;
                    }
            }
            return;
        }
        
        void output(struct Student s[],int n)  //输出成绩单
        {
            int i;
            for(i=0; i<n; i++)
            {
                printf("%s, %s, ", s[i].num, s[i].name);
                printf("%d, %d, %d, ", s[i].c, s[i].math, s[i].english);
                printf("%d %.1f\n", s[i].grade, s[i].average);
            }
            printf("\n");
            return;
        }
        
        void outputExcellent(struct Student s[],int n)   //输出优秀者
        {
            int i;
            for(i=0; i<n; i++)
                if(s[i].grade>=285&&s[i].c>=90&&s[i].math>=90&&s[i].english>=90)
                {
                    printf("%s, %s, ", s[i].num, s[i].name);
                    printf("%d, %d, %d, ", s[i].c, s[i].math, s[i].english);
                    printf("%d %.1f\n", s[i].grade, s[i].average);
                }
            printf("\n");
            return;
        }
        
        • 1

        Information

        ID
        1433
        Time
        1000ms
        Memory
        256MiB
        Difficulty
        8
        Tags
        # Submissions
        101
        Accepted
        18
        Uploaded By