要求矩阵每行的最大值,可以使用双重循环遍历矩阵的每一行,然后在每一行中找到最大的元素。
下面是一个示例代码:
#include <stdio.h>
#define ROWS 3
#define COLS 4
void findMaxInRows(int matrix[ROWS][COLS], int maxValues[ROWS]) {
for (int i = 0; i < ROWS; i++) {
int max = matrix[i][0]; // 假设当前行的第一个元素为最大值
for (int j = 1; j < COLS; j++) {
if (matrix[i][j] > max) { // 如果当前元素大于最大值,则更新最大值
max = matrix[i][j];
}
}
maxValues[i] = max; // 将最大值保存到数组中
}
}
int main() {
int matrix[ROWS][COLS] = {
{ 1, 2, 3, 4 },
{ 5, 6, 7, 8 },
{ 9, 10, 11, 12 }
};
int maxValues[ROWS];
findMaxInRows(matrix, maxValues);
for (int i = 0; i < ROWS; i++) {
printf("Max value in row %d: %d\n", i, maxValues[i]);
}
return 0;
}
运行结果:
Max value in row 0: 4
Max value in row 1: 8
Max value in row 2: 12
在 findMaxInRows
函数中,我们首先假设每一行的第一个元素为最大值,然后通过遍历当前行的所有元素,如果找到比当前最大值更大的元素,则更新最大值。最后将最大值保存到 maxValues
数组中,并在 main
函数中打印出来。