解题思路:
注意事项:
参考代码:
#include<stdio.h> #include<malloc.h>
typedef struct student { char s_num[10]; char name[15]; int subject[3]; }stu; int main() { int N,i = 0,j = 0 ,sum[3] = {0}; //在C语言中一般视大写的字母代表的是常量 scanf("%d", &N); stu* p = (stu*)malloc(N * sizeof(stu)); for (i = 0; i < N; i++) scanf("%s%s%d%d%d", p[i].s_num, p[i].name, &p[i].subject[0], &p[i].subject[1], &p[i].subject[2]); for (i = 0; i < N; i++) //通过for循环,实现了计总分,和最高分的查询 { sum[0]+=p[i].subject[0]; //续上:因为要找到最高的分数,因而必须要有循环,所以没有必要 sum[1]+=p[i].subject[1]; //再设一个循环,在这个循环中就可以计算出总分和,最高分对应的j sum[2]+=p[i].subject[2]; if((p[i].subject[0]+p[i].subject[1]+p[i].subject[2])>(p[j].subject[0]+p[j].subject[1]+p[j].subject[2])) { j = i; } } printf("%d %d %d\n",sum[0]/N,sum[1]/N,sum[2]/N); printf("%s %s %d %d %d", p[j].s_num, p[j].name, p[j].subject[0], p[j].subject[1], p[j].subject[2]); }
0.0分
0 人评分
C语言训练-排序问题<2> (C++代码)(sort函数)浏览:1581 |
数列 (C++代码)浏览:664 |
C语言程序设计教程(第三版)课后习题7.4 (C语言代码)浏览:566 |
数组输出 (C语言代码)浏览:767 |
钟神赛车 (C++代码)浏览:866 |
高精度加法 (C++代码)(大数加法)浏览:934 |
P1002 (C语言代码)浏览:980 |
C语言训练-阶乘和数* (C语言代码)-------- 呆板写法浏览:1362 |
C语言程序设计教程(第三版)课后习题11.8 (C语言代码)浏览:886 |
C语言训练-计算t=1+1/2+1/3+...+1/n (C语言代码)浏览:908 |