悠游


私信TA

用户名:uq_87643911115

访问量:6729

签 名:

你好

等  级
排  名 42
经  验 12748
参赛次数 0
文章发表 206
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

大家好!我是糕手

解题思路:

注意事项:

注意只有前五名才有奖学金
参考代码:

#include<stdio.h>
struct student 
{
    int sno;
    int Chinese;
    int math;
    int English;
    int sum;
};
int main()
{
	int n;
	scanf("%d",&n);
	struct student grade[n];
	for(int i=0;i<n;i++)
	{
	    grade[i].sno=i+1;
	    scanf("%d%d%d",&grade[i].Chinese,&grade[i].math,&grade[i].English);
	    grade[i].sum=grade[i].Chinese+grade[i].math+grade[i].English;
	}
	for(int i=0;i<n;i++)
	{
	    for(int j=i+1;j<n;j++)
	    {
	        struct student a;//结构体变量
	        if(grade[i].sum<grade[j].sum)//总分比较
	        {
	            a=grade[i];
	            grade[i]=grade[j];
	            grade[j]=a;
	        }
	        else if(grade[i].sum==grade[j].sum)//总分相等时
	        {
	            if(grade[i].Chinese<grade[j].Chinese)
	            {
	                a=grade[i];
	                grade[i]=grade[j];
	                grade[j]=a;
	            }
	            else if(grade[i].Chinese==grade[j].Chinese)//语文成绩相等时
	            {
	                if(grade[i].sno>grade[j].sno)
	                {
	                    a=grade[i];
	                    grade[i]=grade[j];
	                    grade[j]=a;
	                }
	            }
	        }
	    }
	}
	for(int i=0;i<5;i++)//注意阿,只有前五名才能获得奖学金
	{
	    printf("%d %d\n",grade[i].sno,grade[i].sum);
	}
	return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »