(创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹)
目录
第1关:数组、指针和函数综合编程练习1
题目:
用一维数组和指针变量作为函数参数,编程输出某班一门课成绩的最高分及其学号。
测试输入
5
99011 84
99012 83
99013 88
99014 87
99015 61
预期输出:
maxScore = 88, maxNum = 99013
代码思路:
这题的主函数部分代码已经给出,我们只需要根据主函数所给的条件,写出FindMax()函数即可。题目要求返回最高分,所以我们用for循环找出最高分,将其赋给a,然后将a返回即可。
代码表示:
#include <stdio.h> #define ARR_SIZE 40 int FindMax(int score[], long num[], int n, long *pMaxNum); int main(void) { int score[ARR_SIZE], maxScore, n, i; long num[ARR_SIZE], maxNum; printf("Please enter total number:"); scanf("%d", &n); //从键盘输入学生人数n printf("Please enter the number and score:\n"); for(i=0; i<n; i++) //分别以长整型和整型格式输入学生的学号和成绩 { scanf("%ld%d", &num[i], &score[i]); } maxScore = FindMax(score, num, n, &maxNum);//计算最高分及学生学号 printf("maxScore = %d, maxNum = %ld\n", maxScore, maxNum); return 0; } //函数功能:返回最高分及最高分学生的学号 int FindMax(int score[], long num[], int n, long *pMaxNum) { /*************** Begin ***************/ *pMaxNum=num[0]; int a = score[0]; for(int i = 0;i<n-1;i++) { if(score[i]<score[i+1]) { *pMaxNum=num[i+1]; a=score[i+1]; } } return a; /*************** End ***************/ }
第2关:数组、指针和函数综合编程练习2
题目:
本关任务:数组、指针和函数综合编程练习。
用二维数组和指针变量作为函数参数,编程输出三个班学生(假设每班4个学生)的某门课成绩的最高分,并指出具有该最高分成绩的学生是第几个班的第几个学生。
测试输入
81 72 73 64
65 86 77 88
91 90 85 92
预期输出:
maxScore = 92, class = 3, number = 4
代码思路:
这题和上一题思路一样,根据主函数给出的代码,我们可以判断出需要返回最高分maxScore的值,并且要将班级和学号赋给 row 和 col ,因此我们可以用双层for循环实现二维数组的比较,得到最大值和其相应数据后赋值返回即可
代码表示:
#include <stdio.h> #define CLASS 3 #define STU 4 int FindMax(int score[CLASS][STU], int m, int *pRow, int *pCol); int main(void) { int score[CLASS][STU], i, j, maxScore, row, col; printf("Please enter score:\n"); for (i=0; i<CLASS; i++) { for (j=0; j<STU; j++) { scanf("%d", &score[i][j]); //输入学生成绩 } } //计算最高分及其学生所在班号和学号 maxScore = FindMax(score, CLASS, &row, &col); printf("maxScore = %d, class = %d, number = %d\n", maxScore, row+1, col+1); return 0; } //函数功能:返回任意m行STU列二维数组中元素的最大值,并指出其所在行列下标值 int FindMax(int score[][STU], int m, int *pRow, int *pCol) { /*************** Begin ***************/ int a = score[0][0]; for(int i = 0;i<CLASS;i++) { for(int j=0; j<STU-1; j++) { if(a<score[i][j+1]) { a=score[i][j+1]; *pRow=i; *pCol=j+1; } } } return a; /*************** End ***************/ }
第3关:数组、指针和函数综合编程练习3
题目:
本关任务:数组、指针和函数综合编程练习。
用指向二维数组第0行第0列元素的指针作为函数参数,编写一个计算任意 m 行 n 列二维数组中元素的最大值,并指出其所在的行列下标值的函数,利用该函数计算三个班学生(假设每班4个学生)的某门课成绩的最高分,并指出具有该最高分成绩的学生是第几个班的第几个学生。
测试输入
81 72 73 64
65 86 77 88
91 90 85 92
预期输出:
maxScore = 92, class = 3, number = 4
代码思路:
本题和上一题一样,只是将二维数组改成了指针( score[0][0]表示p[0],score[0][1]表示p[1] ),方法也和上一题一样
代码表示:
#include <stdio.h> #define CLASS 3 #define STU 4 int FindMax(int *p, int m, int n, int *pRow, int *pCol); int main(void) { int score[CLASS][STU], i, j, maxScore, row, col; printf("Please enter score:\n"); for (i=0; i<CLASS; i++) { for (j=0; j<STU; j++) { scanf("%d", &score[i][j]); //输入学生成绩 } } //计算最高分及其学生所在班号和学号 maxScore = FindMax(*score, CLASS, STU, &row, &col); printf("maxScore = %d, class = %d, number = %d\n", maxScore, row+1, col+1); return 0; } //函数功能:返回任意m行n列的二维数组中元素的最大值,并指出其所在的行列下标值 int FindMax(int *p, int m, int n, int *pRow, int *pCol) { /*************** Begin ***************/ int a=p[0]; for (int i=0; i<CLASS; i++) { for (int j=0; j<STU; j++) { if(a<p[i*n+j]) { a=p[i*n+j]; *pRow=i; *pCol=j; } } } return a; /*************** End ***************/ }
第4关:数组、指针和函数综合编程练习4
题目:
本关任务:数组、指针和函数综合编程练习。
编写一个计算任意 m 行 n 列二维数组中元素的最大值,并指出其所在的行列下标值的函数,利用该函数和动态内存分配方法,计算任意 m 个班、每班 n 个学生的某门课成绩的最高分,并指出具有该最高分成绩的学生是第几个班的第几个学生。
测试输入
81 72 73 64
65 86 77 88
91 90 85 92
预期输出:
maxScore = 92, class = 3, number = 4
代码思路:
这题和上一题一样,只是将新增加了动态内存分配的方式
代码表示:
#include <stdio.h> #include <stdlib.h> int FindMax(int *p, int m, int n, int *pRow, int *pCol); int main(void) { int *pScore, i, j, m, n, maxScore, row, col; printf("Please enter array size m,n:"); scanf("%d,%d", &m, &n); //输入班级数m和学生数n pScore = (int *) calloc(m*n, sizeof (int)); //申请内存 if (pScore == NULL) { printf("No enough memory!\n"); exit(0); } printf("Please enter the score:\n"); for (i=0; i<m; i++) { for (j=0; j<n; j++) { scanf("%d", &pScore [i*n+j]); //输入学生成绩 } } maxScore = FindMax(pScore, 3, 4, &row, &col); //调用函数FindMax printf("maxScore = %d, class = %d, number = %d\n", maxScore, row+1, col+1); //输出最高分max及其所在的班级和学号 free(pScore); //释放向系统申请的存储空间 return 0; } //函数功能:返回任意m行n列的二维数组中元素的最大值,并指出其所在行列下标值 int FindMax(int *p, int m, int n, int *pRow, int *pCol) { /*************** Begin ***************/ int *a = (int*)malloc(sizeof(int)); for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { if (*a < p[i * n + j]) { *a = p[i * n + j]; *pRow = i; *pCol = j; } } } return *a; /*************** End ***************/ }