c - 添加矩阵/返回一个数组
问题描述
我是 C 的初学者,我在编写一个需要两个矩阵的函数时遇到了一些问题,将它们相加并将结果作为第三个矩阵返回。根本问题是让函数返回一个数组。
我在网上找到了一些关于如何通过返回指向数组第一个元素的指针来返回数组的解决方案,但无法将其应用于我使用二维数组的情况。我知道如何在主函数中添加矩阵,但我需要将程序分解为几个函数。
这是我的代码
float matrix_add(float matrixA[MAX_SIZE][MAX_SIZE], float matrixB[MAX_SIZE][MAX_SIZE], int column, int line)
{
float matrixRes[MAX_SIZE][MAX_SIZE];
for (int i=0; i<column; i++)
{
for (int j=0; j<line; j++)
{
matrixRes[i][j]=matrixA[i][j]+matrixB[i][j];
}
}
return matrixRes;
}
我已经尝试了我在网上找到的解决方案之一:
float *matrix_add(float matrixA[MAX_SIZE][MAX_SIZE], float matrixB[MAX_SIZE][MAX_SIZE], int column, int line)
{
static float *matrixRes[MAX_SIZE][MAX_SIZE];
for (int i=0; i<column; i++)
{
for (int j=0; j<line; j++)
{
*matrixRes[i][j]=matrixA[i][j]+matrixB[i][j];
}
}
return matrixRes;
但是它有一些问题 - 我不明白,并且该函数仍然不起作用 - 它返回错误结果并且编译器中有一个警告“从不兼容的指针类型返回”。另外,我不确定如何调用它(也许这就是我找到的解决方案的问题?)。我想从数组中获取一些特定的值并像这样调用函数
matrix_add(matrixA, matrixB, column, line)[value][value]);
其中 matrixA 和 B 是一些二维数组,column 和 line 是整数变量。这将返回一个错误(下标值既不是数组也不是指针也不是向量)
您能否指出正确的方向并告诉我如何使此功能起作用(并解释解决方案)?MAX_SIZE 是预定义值(10),因为在这个分配中我应该使用静态内存分配(但如果你可以通过使用动态分配来帮助我,那很好)主要功能看起来像这样
int main()
{
int column_num[2], line_num[2];
float matrixA[MAX_SIZE][MAX_SIZE], matrixB[MAX_SIZE][MAX_SIZE];
scanf("%d", &column_num[0]);
scanf("%d", &line_num[0]);
matrix_load_val(matrixA, column_num[0], line_num[0]);
scanf("%d", &column_num[1]);
scanf("%d", &line_num[1]);
matrix_load_val(matrixB, column_num[1], line_num[1]);
}
for (int i=0; i<column_num[0]; i++)
{
for(int j=0; j<line_num[0]; j++)
{
printf("%0.5g\n", matrix_add(matrixA, matrixB, i, j));
}
}
matrix_load_val 是一个程序,它向用户询问值并将它们放入一个结果矩阵中(它确实有效,经过测试)
解决方案
你的尝试并不遥远。您有一个可行的想法来声明一个static
数组并“返回它”,但首先我们需要了解这意味着什么。
在 C 中,数组类型是奇怪的野兽。您不能像在其他语言中那样直接返回值数组。相反,您返回一个指针。我们说数组类型衰减为指针。对于一维数组,这并不太可怕:
float *get_array(void) {
static float my_array[2] = { 1, 2 };
return my_array;
}
float *result = get_array();
对于多维数组,衰减更加棘手和丑陋:
请注意,当应用数组到指针衰减时,多维数组将转换为指向其第一个元素的指针(例如,指向其第一行或第一个平面的指针):数组到指针衰减仅应用一次.
要返回指向二维数组的指针,语法为:
float (*get_array(void))[2] {
static float my_array[2][2] = { { 1, 2 }, { 3, 4 } };
return my_array;
}
float (*result)[2] = get_array();
应用它,我们可以调整您的代码以使其工作(为简洁起见省略了一些大括号):
float (*matrix_add(float matrixA[MAX_SIZE][MAX_SIZE], float matrixB[MAX_SIZE][MAX_SIZE], int column, int line))[MAX_SIZE]
{
static float matrixRes[MAX_SIZE][MAX_SIZE];
for (int i = 0; i < column; ++i)
for (int j = 0; j < line; ++j)
matrixRes[i][j] = matrixA[i][j] + matrixB[i][j];
return matrixRes;
}
然而,对于这种类型的事情,一个更惯用的 C 模式是让调用者传入一个指向输出数组的指针。然后该函数填充此数组。这称为输出参数。这也消除了static
变量及其相关问题(例如线程安全和后续调用破坏了先前调用的结果)。
void matrix_add(
const float matrixA[MAX_SIZE][MAX_SIZE], /* "input parameter" */
const float matrixB[MAX_SIZE][MAX_SIZE], /* "input parameter" */
float matrixRes[MAX_SIZE][MAX_SIZE], /* "output parameter" */
int column,
int line)
{
for (int i = 0; i < column; ++i)
for (int j = 0; j < line; ++j)
matrixRes[i][j] = matrixA[i][j] + matrixB[i][j];
}
请注意,我们还设置了输入参数const
以反映函数不修改这些数组的事实。这可以从函数的原型中清楚地看出哪些是输入参数,哪些是输出参数。
* 我还冒昧地重新格式化了一下,并更改i++
为,++i
因为这是一个好习惯,尽管在这种特殊情况下没有区别。
推荐阅读
- tableau-api - 为什么跨国公司需要人员来处理 Power BI?
- javascript - Ajax 和异步等待
- oracle-apex-5.1 - Oracle APEX 图表 - 显示无效数据
- fortran - pgf90 在使用可选逻辑参数时导致分段错误
- ssl - 多层系统中 TLS 协议的传播方式
- makefile - GNU Make 只执行 10 条规则
- mesos - 我们是否必须在每个节点上编译 Mesos?
- c++ - Qt 使用 exec() 循环测试 QMessageBoxes(或通用 QDialog)
- jquery - 从html中的表单提交中排除隐藏元素
- android - 发布带有风味的 android 库