解题思路:本方法旨在体会和锻炼使用指针寻址,放弃对结构体数组直接操作,通过指针加减完成

注意事项:注意结构体指针方法,p是一个指针,但p->num是该指针指向结构的一个成员,是一个char类型变量,同理可得......
参考代码:

#include<stdio.h>

#include<stdlib.h>

struct score

{

    char num  [30];

    char name [30];

    int goal [3];

};

int main()

{

   int n,i,x,y,t,bingo=0,average,j;

   scanf("%d",&n);

   getchar();

   int sum[n],com[n];

   struct score H[n];

   struct score *p;

   //struct score *p=(struct score*)malloc(sizeof(struct score)*2);

    p=H;

   for(i=0;i<n;i++)

   {

      scanf("%s %s %d %d %d",&p->num,&p->name,&p->goal[0],&p->goal[1],&p->goal[2]);

      sum[i]=p->goal[0]+p->goal[1]+p->goal[2];

      com[i]=p->goal[0]+p->goal[1]+p->goal[2];

      p++;

   }

   p=H;

   for(x=0;x<n-1;x++)//将总成绩排序

    {

        for(y=x;y<n-1;y++)

        {

            if(com[y]>com[y+1])

            {

            t=com[y];com[y]=com[y+1];com[y+1]=t;

            }

         }

    }

    for(i=0;i<n;i++)//找到最高分同学位置

    {

        if(sum[i]==com[n-1]) bingo=i;

    }

    //printf("%d\n",bingo);


    for(i=0;i<3;i++)//求各科平均分

    {

       int ave=0;

       for(j=0;j<n;j++)

       {

           ave=ave+((p+j)->goal[i]);//

       }

       average=ave/n;

       if(i==0) printf("%d",average);

       else if(i==2)  printf(" %d\n",average);

       else  printf(" %d",average);

    }

    printf("%s %s %d %d %d\n",(p+bingo)->num,(p+bingo)->name,(p+bingo)->goal[0],(p+bingo)->goal[1],(p+bingo)->goal[2]);

}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论