解题思路:本方法旨在体会和锻炼使用指针寻址,放弃对结构体数组直接操作,通过指针加减完成
注意事项:注意结构体指针方法,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 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复