头歌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 ***************/
}


相关文章
|
25天前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
41 8
|
29天前
|
C语言
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性。本文探讨了C语言中的错误类型(如语法错误、运行时错误)、基本处理方法(如返回值、全局变量、自定义异常处理)、常见策略(如检查返回值、设置标志位、记录错误信息)及错误处理函数(如perror、strerror)。强调了不忽略错误、保持处理一致性及避免过度处理的重要性,并通过文件操作和网络编程实例展示了错误处理的应用。
64 4
|
29天前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
1月前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
1月前
|
容器
在使用指针数组进行动态内存分配时,如何避免内存泄漏
在使用指针数组进行动态内存分配时,避免内存泄漏的关键在于确保每个分配的内存块都能被正确释放。具体做法包括:1. 分配后立即检查是否成功;2. 使用完成后及时释放内存;3. 避免重复释放同一内存地址;4. 尽量使用智能指针或容器类管理内存。
|
1月前
|
存储 NoSQL 编译器
C 语言中指针数组与数组指针的辨析与应用
在C语言中,指针数组和数组指针是两个容易混淆但用途不同的概念。指针数组是一个数组,其元素是指针类型;而数组指针是指向数组的指针。两者在声明、使用及内存布局上各有特点,正确理解它们有助于更高效地编程。
|
1月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
128 13
|
2月前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
38 0
|
3月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第八章 指针超详细讲解_指针变量_二维数组指针_指向字符串指针
本文详细讲解了C语言中的指针,包括指针变量的定义与引用、指向数组及字符串的指针变量等。首先介绍了指针变量的基本概念和定义格式,随后通过多个示例展示了如何使用指针变量来操作普通变量、数组和字符串。文章还深入探讨了指向函数的指针变量以及指针数组的概念,并解释了空指针的意义和使用场景。通过丰富的代码示例和图形化展示,帮助读者更好地理解和掌握C语言中的指针知识。
144 4
|
4月前
|
C语言
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)
【C初阶——指针5】鹏哥C语言系列文章,基本语法知识全面讲解——指针(5)