头歌C语言实训项目-数组、指针和函数综合编程练习

简介: 头歌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返回即可。

代码表示:  

#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 ***************/
}


相关文章
|
12天前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
50 24
|
7天前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
46 16
|
7天前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
19 3
|
7天前
|
存储 算法 安全
【C语言程序设计——函数】分数数列求和1(头歌实践教学平台习题)【合集】
if 语句是最基础的形式,当条件为真时执行其内部的语句块;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。常量的值必须是唯一的,且在同一个。
11 2
|
11天前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
41 1
|
8月前
|
C语言
c语言编程练习题:7-10 算术入门之加减乘除
对于输入的两个整数,按照要求输出其和差积商。
130 0
|
存储 C语言 数据格式
【手把手带你刷题】-C语言编程入门篇(四)
【手把手带你刷题】-C语言编程入门篇(四)
82 0
|
机器学习/深度学习 存储 C语言
【手把手带你刷题】-C语言编程入门篇(三)
【手把手带你刷题】-C语言编程入门篇(三)
79 0
|
C语言
【手把手带你刷题】-C语言编程入门篇(二)
【手把手带你刷题】-C语言编程入门篇(二)
66 0
|
C语言
【手把手带你刷题】-C语言编程入门篇(一)
【手把手带你刷题】-C语言编程入门篇(一)
96 0