「已注销」 2021-06-22 10:26 采纳率: 22.2%
浏览 12

急急急!!!!!!c语音

c语言,做个学习成绩录入表要求如下

(1)录入每个学生的学号和考试成绩;

 

(2)计算课程的总分和平均分;

 

(3)按成绩由高到低排出名次表;

 

(4)按成绩由低到高排出名次表

 

(5)按学号由小到大排出成绩表

 

(6)按学号查询学生排名及其考试成绩;

 

(7)按优秀(90~100)、良好(80~89)、中等(70~79)、格《60~69)、不及格(0~59)5个类别,统计每个类别的人数以及所占的百分

  • 写回答

1条回答 默认 最新

  • qfl_sdu 2021-06-22 10:30
    关注

    全是排序啊,看看排序算法就搞定了啊。

    下面代码是按照平均分排序的,其它排序修改一下排序的内容就可以了。

    #include <stdio.h>
    struct Student
    {
    	int nmb;
    	char name[20];
    	int score[3];
    };
    //录入数据
    void inputinfo(struct Student a[])
    {
    	int i;
    	printf("输入10个学生的学号,姓名,三门课的成绩:\n");
    	for (i = 0;i< 10;i++)
    	{
    		scanf("%d %s %d %d %d",&a[i].nmb,a[i].name,&a[i].score[0],&a[i].score[1],&a[i].score[2]);
    	}
    }
    //科目成绩最高的学生信息
    void maxinfo(struct Student a[])
    {
    	int i;
    	int max1,max2,max3;
    	int index1 = 0,index2 = 0,index3 = 0;
    	max1 = a[0].score[0];
    	max2 = a[0].score[1];
    	max3 = a[0].score[2];
    	for (i = 1;i<10;i++)
    	{
    		if (a[i].score[0] > max1)
    		{
    			max1 = a[i].score[0];
    			index1 = i;
    		}
    
    		if (a[i].score[1] > max2)
    		{
    			max2 = a[i].score[1];
    			index2 = i;
    		}
    
    		if (a[i].score[2] > max3)
    		{
    			max3 = a[i].score[2];
    			index3 = i;
    		}
    	}
    
    	printf("科目1成绩最高的学生:%d\t%s\t%d\n",a[index1].nmb,a[index1].name,a[index1].score[0]);
    	printf("科目2成绩最高的学生:%d\t%s\t%d\n",a[index2].nmb,a[index2].name,a[index2].score[1]);
    	printf("科目3成绩最高的学生:%d\t%s\t%d\n",a[index3].nmb,a[index3].name,a[index3].score[2]);
    
    }
    //平均成绩最高的学生信息
    void avginfo(struct Student a[])
    {
    	int i = 0;
    	float avg = 0.0;
    	float maxavg = (a[0].score[0] + a[0].score[1]+a[0].score[2])/3.0;
    	int index =0;
    	for (i = 1;i<10;i++)
    	{
    		avg = (a[i].score[0] + a[i].score[1]+a[i].score[2])/3.0;
    		if (avg > maxavg)
    		{
    			maxavg = avg;
    			index = i;
    		}
    	}
    	printf("平均分最高的学生:%d\t%s\t%.2f\n",a[index].nmb,a[index].name,maxavg);
    }
    
    //按平均分从高到低排序
    void Sort(struct Student a[])
    {
    	int i,j;
    	float avg1,avg2;
    	struct Student tmp;
    	for (i = 0;i< 9;i++)
    	{
    		for (j = 0;j< 9-i;j++)
    		{
    			avg1 = (a[j].score[0] + a[j].score[1]+a[j].score[2])/3.0;
    			avg2 = (a[j+1].score[0] + a[j+1].score[1]+a[j+1].score[2])/3.0;
    			if(avg1 < avg2)
    			{
    				tmp = a[j];
    				a[j] = a[j+1];
    				a[j+1] = tmp;
    			}
    		}
    	}
    	printf("number	name	math	Chinese	English	average\n");
    	for (i = 0;i<10;i++)
    	{
    		avg1 = (a[i].score[0] + a[i].score[1]+a[i].score[2])/3.0;
    		printf("%d\t%s\t%d\t%d\t%d\t%.2f\n",a[i].nmb,a[i].name,a[i].score[0],a[i].score[1],a[i].score[2],avg1);
    	}
    }
    
    int main()
    {
    	struct Student a[10];
    	inputinfo(a);
    	maxinfo(a);
    	avginfo(a);
    	Sort(a);
    	return 0;
    }
    
    评论

报告相同问题?