解题思路:
注意事项:
参考代码:
#include<stdio.h>
#include<stdlib.h>
struct student{
char xuehao[5];
char name[20];
int score[3];
};
void input(struct student *p,int n){
for(int i=0;i<n;i++){
scanf("%s%s%d%d%d",p->xuehao,p->name,&p->score[0],&p->score[1],&p->score[2]);
p++;
}
p=p-n;
}
void print(struct student *p,int n){
for(int i=0;i<n;i++){
printf("%s,%s,%d,%d,%d\n",p->xuehao,p->name,p->score[0],p->score[1],p->score[2]);
p++;
}
p=p-n;
}
struct student * max(struct student *p,int n){
int max=0,m=0;
int *sum = (int *)malloc(sizeof(int)*n);
struct student *q=p;
for(int i=0;i<n;i++){
*sum=p->score[0]+p->score[1]+p->score[2];
p++;
sum++;
}
p-=n;
sum-=n;
for(int i=0;i<n;i++){
if(max<*(sum+i)){
max=*(sum+i);
q=p;
}
p++;
}
p=p-n;
return q;
}
int main(){
int N,i;
int score1=0,score2=0,score3=0;
scanf("%d",&N);
void input(struct student *p,int n);
void print(struct student *p,int n);
struct student * max(struct student *p,int n);
struct student *p = (struct student *)malloc(sizeof(struct student)*N);
struct student *q=p;
input(p,N);
for(int i=0;i<N;i++){
score1+=p->score[0];
score2+=p->score[1];
score3+=p->score[2];
p++;
}
p=p-N;
printf("%d %d %d\n",score1/N,score2/N,score3/N);
q=max(p,N);
printf("%s %s %d %d %d\n",q->xuehao,q->name,q->score[0],q->score[1],q->score[2]);
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复