解题思路:本方法旨在体会和锻炼使用指针寻址,放弃对结构体数组直接操作,通过指针加减完成
注意事项:注意结构体指针方法,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语言代码)浏览:851 |
简单的a+b (C语言代码)浏览:489 |
高精度加法 (C++代码)(大数加法)浏览:916 |
C语言程序设计教程(第三版)课后习题10.7 (C语言代码)浏览:525 |
C语言程序设计教程(第三版)课后习题9.3 (Java代码)浏览:956 |
A+B for Input-Output Practice (V) (C++代码)浏览:450 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:548 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:935 |
1017题解浏览:581 |
1024题解浏览:806 |