/*输入m个学生(最多为30人)n门课程(最多为5门)的成绩,
然后计算并打印每个学生各门课的总分和平均分。*/
//下面这个程序的问题是什么?
#include <stdio.h>
#define STUD 30 /* 最多可能的学生人数 */
#define COURSE 5 /* 最多可能的考试科目数 */
void Total(int *pScore, int sum[], float aver[], int m, int n);
void Print(int *pScore, int sum[], float aver[], int m, int n);
int main()
{
int i, j, m, n, score[STUD][COURSE], sum[STUD];
float aver[STUD];
printf("How many students?");
scanf("%d", &m);
printf("How many courses?");
scanf("%d", &n);
printf("Input scores:\n");
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
scanf("%d", &score[i][j]);
}
}
Total(*score, sum, aver, m, n);
Print(*score, sum, aver, m, n);
return 0;
}
void Total(int *pScore, int sum[], float aver[], int m, int n)
{
int i, j;
for (i = 0; i < m; i++)
{
sum[i] = 0;
for (j = 0; j < n; j++)
{
sum[i] = sum[i] + pScore[i*n+j];
}
aver[i] = (float) sum[i] / n;
}
}
void Print(int *pScore, int sum[], float aver[], int m, int n)
{
int i, j;
printf("Result:\n");
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
printf("%4d\t", pScore[i * n + j]);
}
printf("%5d\t%6.1f\n", sum[i], aver[i]);
}
}
/*问题:
line23:读入时是按照二维数组来读入的;而
line38、51:使用时是按一维数组来用的(列指针),
所以如果输入的m、n小于最大值,使用时就会用到未被赋值的元素。
eg:
m=2,n=3时,
二维数组读入时:
1 2 3 x x
4 5 6 x x
x x x x x
...
一维数组使用时:
1 2 3 x x
*/
/*措施:
<之一>使用列指针时按每行 COURSE个元素处理: pScore[i * n + j]-->pScore[i * 5 + j]
<之二>读入时也用列指针读入:
void Input(int *pScore, int m, int n)
{
int i, j;
printf("Input scores:\n");
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
scanf("%d", &pScore[i * n + j]);
}
}
}
<之三>使用时用数组或行指针不用列指针:...*/
/*问题:
line23:读入时是按照二维数组来读入的;而
line38、51:使用时是按一维数组来用的(列指针),
所以如果输入的m、n小于最大值,使用时就会用到未被赋值的元素。
eg:
m=2,n=3时,
二维数组读入时:
1 2 3 x x
4 5 6 x x
x x x x x
...
一维数组使用时:
1 2 3 x x
*/
/*措施:
<之一>使用列指针时按每行 COURSE个元素处理: pScore[i * n + j]-->pScore[i * 5 + j]
<之二>读入时也用列指针读入:
void Input(int *pScore, int m, int n)
{
int i, j;
printf("Input scores:\n");
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
scanf("%d", &pScore[i * n + j]);
}
}
}
<之三>使用时用数组或行指针不用列指针:...*/