解题思路:本方法旨在体会和锻炼使用指针寻址,放弃对结构体数组直接操作,通过指针加减完成
注意事项:注意结构体指针方法,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语言训练-求矩阵的两对角线上的元素之和 (C语言代码)浏览:3472 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:689 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:545 |
C语言程序设计教程(第三版)课后习题5.5 (C语言代码)浏览:737 |
2006年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:674 |
简单的a+b (C语言代码)浏览:661 |
1012题解浏览:938 |
1124题解浏览:630 |
字符串输入输出函数 (C语言代码)浏览:2605 |
printf基础练习2 (C语言代码)浏览:547 |