头歌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 ***************/
}
  • 8
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小周不摆烂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值