解题思路:

注意事项:

参考代码:


#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分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论