当前位置:   article > 正文

头歌C语言实训项目-数组、指针和函数综合编程练习_头歌实践教学平台 数组综合实训(公共实验四)

头歌实践教学平台 数组综合实训(公共实验四)

  (创作不易,感谢有你,你的支持,就是我前行的最大动力,如果看完对你有帮助,请留下您的足迹)

目录

第1关:数组、指针和函数综合编程练习1

题目:

代码思路:

代码表示: 

第2关:数组、指针和函数综合编程练习2 

题目:

代码思路:

代码表示: 

第3关:数组、指针和函数综合编程练习3 

题目:

代码思路:

代码表示: 

第4关:数组、指针和函数综合编程练习4 

题目:

代码思路:

代码表示: 


第1关:数组、指针和函数综合编程练习1

题目:

用一维数组和指针变量作为函数参数,编程输出某班一门课成绩的最高分及其学号。

测试输入

5

99011 84

99012 83

99013 88

99014 87

99015 61

预期输出:

maxScore = 88, maxNum = 99013

代码思路:

这题的主函数部分代码已经给出,我们只需要根据主函数所给的条件,写出FindMax()函数即可。题目要求返回最高分,所以我们用for循环找出最高分,将其赋给a,然后将a返回即可。

代码表示: 

  1. #include <stdio.h>
  2. #define ARR_SIZE 40
  3. int FindMax(int score[], long num[], int n, long *pMaxNum);
  4. int main(void)
  5. {
  6. int score[ARR_SIZE], maxScore, n, i;
  7. long num[ARR_SIZE], maxNum;
  8. printf("Please enter total number:");
  9. scanf("%d", &n); //从键盘输入学生人数n
  10. printf("Please enter the number and score:\n");
  11. for(i=0; i<n; i++) //分别以长整型和整型格式输入学生的学号和成绩
  12. {
  13. scanf("%ld%d", &num[i], &score[i]);
  14. }
  15. maxScore = FindMax(score, num, n, &maxNum);//计算最高分及学生学号
  16. printf("maxScore = %d, maxNum = %ld\n", maxScore, maxNum);
  17. return 0;
  18. }
  19. //函数功能:返回最高分及最高分学生的学号
  20. int FindMax(int score[], long num[], int n, long *pMaxNum)
  21. {
  22. /*************** Begin ***************/
  23. *pMaxNum=num[0];
  24. int a = score[0];
  25. for(int i = 0;i<n-1;i++)
  26. {
  27. if(score[i]<score[i+1])
  28. {
  29. *pMaxNum=num[i+1];
  30. a=score[i+1];
  31. }
  32. }
  33. return a;
  34. /*************** End ***************/
  35. }

第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循环实现二维数组的比较,得到最大值和其相应数据后赋值返回即可

代码表示: 

  1. #include <stdio.h>
  2. #define CLASS 3
  3. #define STU 4
  4. int FindMax(int score[CLASS][STU], int m, int *pRow, int *pCol);
  5. int main(void)
  6. {
  7. int score[CLASS][STU], i, j, maxScore, row, col;
  8. printf("Please enter score:\n");
  9. for (i=0; i<CLASS; i++)
  10. {
  11. for (j=0; j<STU; j++)
  12. {
  13. scanf("%d", &score[i][j]); //输入学生成绩
  14. }
  15. }
  16. //计算最高分及其学生所在班号和学号
  17. maxScore = FindMax(score, CLASS, &row, &col);
  18. printf("maxScore = %d, class = %d, number = %d\n",
  19. maxScore, row+1, col+1);
  20. return 0;
  21. }
  22. //函数功能:返回任意m行STU列二维数组中元素的最大值,并指出其所在行列下标值
  23. int FindMax(int score[][STU], int m, int *pRow, int *pCol)
  24. {
  25. /*************** Begin ***************/
  26. int a = score[0][0];
  27. for(int i = 0;i<CLASS;i++)
  28. {
  29. for(int j=0; j<STU-1; j++)
  30. {
  31. if(a<score[i][j+1])
  32. {
  33. a=score[i][j+1];
  34. *pRow=i;
  35. *pCol=j+1;
  36. }
  37. }
  38. }
  39. return a;
  40. /*************** End ***************/
  41. }

第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] ),方法也和上一题一样

代码表示: 

  1. #include <stdio.h>
  2. #define CLASS 3
  3. #define STU 4
  4. int FindMax(int *p, int m, int n, int *pRow, int *pCol);
  5. int main(void)
  6. {
  7. int score[CLASS][STU], i, j, maxScore, row, col;
  8. printf("Please enter score:\n");
  9. for (i=0; i<CLASS; i++)
  10. {
  11. for (j=0; j<STU; j++)
  12. {
  13. scanf("%d", &score[i][j]); //输入学生成绩
  14. }
  15. }
  16. //计算最高分及其学生所在班号和学号
  17. maxScore = FindMax(*score, CLASS, STU, &row, &col);
  18. printf("maxScore = %d, class = %d, number = %d\n",
  19. maxScore, row+1, col+1);
  20. return 0;
  21. }
  22. //函数功能:返回任意m行n列的二维数组中元素的最大值,并指出其所在的行列下标值
  23. int FindMax(int *p, int m, int n, int *pRow, int *pCol)
  24. {
  25. /*************** Begin ***************/
  26. int a=p[0];
  27. for (int i=0; i<CLASS; i++)
  28. {
  29. for (int j=0; j<STU; j++)
  30. {
  31. if(a<p[i*n+j])
  32. {
  33. a=p[i*n+j];
  34. *pRow=i;
  35. *pCol=j;
  36. }
  37. }
  38. }
  39. return a;
  40. /*************** End ***************/
  41. }

第4关:数组、指针和函数综合编程练习4 

题目:

本关任务:数组、指针和函数综合编程练习。

编写一个计算任意 m 行 n 列二维数组中元素的最大值,并指出其所在的行列下标值的函数,利用该函数和动态内存分配方法,计算任意 m 个班、每班 n 个学生的某门课成绩的最高分,并指出具有该最高分成绩的学生是第几个班的第几个学生。

测试输入

81 72 73 64

65 86 77 88

91 90 85 92

预期输出:

maxScore = 92, class = 3, number = 4

代码思路:

 这题和上一题一样,只是将新增加了动态内存分配的方式

代码表示: 

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. int FindMax(int *p, int m, int n, int *pRow, int *pCol);
  4. int main(void)
  5. {
  6. int *pScore, i, j, m, n, maxScore, row, col;
  7. printf("Please enter array size m,n:");
  8. scanf("%d,%d", &m, &n); //输入班级数m和学生数n
  9. pScore = (int *) calloc(m*n, sizeof (int)); //申请内存
  10. if (pScore == NULL)
  11. {
  12. printf("No enough memory!\n");
  13. exit(0);
  14. }
  15. printf("Please enter the score:\n");
  16. for (i=0; i<m; i++)
  17. {
  18. for (j=0; j<n; j++)
  19. {
  20. scanf("%d", &pScore [i*n+j]); //输入学生成绩
  21. }
  22. }
  23. maxScore = FindMax(pScore, 3, 4, &row, &col); //调用函数FindMax
  24. printf("maxScore = %d, class = %d, number = %d\n",
  25. maxScore, row+1, col+1); //输出最高分max及其所在的班级和学号
  26. free(pScore); //释放向系统申请的存储空间
  27. return 0;
  28. }
  29. //函数功能:返回任意m行n列的二维数组中元素的最大值,并指出其所在行列下标值
  30. int FindMax(int *p, int m, int n, int *pRow, int *pCol)
  31. {
  32. /*************** Begin ***************/
  33. int *a = (int*)malloc(sizeof(int));
  34. for (int i = 0; i < m; i++)
  35. {
  36. for (int j = 0; j < n; j++)
  37. {
  38. if (*a < p[i * n + j])
  39. {
  40. *a = p[i * n + j];
  41. *pRow = i;
  42. *pCol = j;
  43. }
  44. }
  45. }
  46. return *a;
  47. /*************** End ***************/
  48. }
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/647110
推荐阅读
相关标签
  

闽ICP备14008679号