FoolHungry


私信TA

用户名:hitee

访问量:672

签 名:

Stay Hungry Stay Foolish

等  级
排  名 28473
经  验 534
参赛次数 0
文章发表 3
年  龄 0
在职情况 学生
学  校 HIT
专  业 EE

  自我简介:

Stepping EE Master

TA的其他文章

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

注意事项:注意结构体指针方法,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分

1 人评分

  评论区

  • «
  • »