C //例 7.13 有一个3*4的矩阵,求所有元素中的最大值。

C程序设计 (第四版) 谭浩强 例 7.13

例 7.13 有一个3*4的矩阵,求所有元素中的最大值。

IDE工具:VS2010
Note: 使用不同的IDE工具可能有部分差异。
代码块
方法:使用指针、动态分配内存
c 复制代码
#include <stdio.h>
#include <stdlib.h>

#define M 3
#define N 4

void initialMatrix(int ***matrix, int m, int n){
	*matrix = (int**)malloc(m * sizeof(int*));
	for(int i = 0; i < m; i++){
		(*matrix)[i] = (int*)malloc(n * sizeof(int));
	}
}

void inputMatrix(int **matrix, int m, int n){
	printf("Enter %d*%d matrix:\n", m, n);
	for(int i = 0; i < m; i++){
		for(int j = 0; j < n; j++){
			scanf("%d", &matrix[i][j]);
		}
	}
}

int max(int **matrix, int m, int n){
	int max = matrix[0][0];
	for(int i = 0; i < m; i++){
		for(int j = 0; j < n; j++){
			if(matrix[i][j] > max){
				max = matrix[i][j];
			}
		}
	}
	return max;
}

void outputMatrix(int **matrix, int m, int n, int max(int **, int, int)){
	printf("Max Value in the matrix is %d\n", max(matrix, m, n));
}

void freeMatrix(int ***matrix, int m){
	for(int i = 0; i < m; i++){
		free((*matrix)[i]);
	}
	free(*matrix);
}

int main(){
	int **matrix = NULL;

	initialMatrix(&matrix, M, N);
	inputMatrix(matrix, M, N);
	outputMatrix(matrix, M, N, max);
	freeMatrix(&matrix, M);

	system("pause");
	return 0;
}
相关推荐
Jess0741 分钟前
插入排序的简单介绍
数据结构·算法·排序算法
老一岁42 分钟前
选择排序算法详解
数据结构·算法·排序算法
xindafu1 小时前
代码随想录算法训练营第四十二天|动态规划part9
算法·动态规划
xindafu1 小时前
代码随想录算法训练营第四十五天|动态规划part12
算法·动态规划
ysa0510302 小时前
Dijkstra 算法#图论
数据结构·算法·图论
一定要AK2 小时前
2025—暑期训练一
算法
一定要AK2 小时前
贪心专题练习
算法
森焱森3 小时前
无人机三轴稳定控制(2)____根据目标俯仰角,实现俯仰稳定化控制,计算出升降舵输出
c语言·单片机·算法·架构·无人机
ytttr8734 小时前
matlab通过Q学习算法解决房间路径规划问题
学习·算法·matlab
go54631584655 小时前
修改Spatial-MLLM项目,使其专注于无人机航拍视频的空间理解
人工智能·算法·机器学习·架构·音视频·无人机