C语言——矩阵转置
创始人
2024-03-09 01:32:55
0

矩阵转置的原理:行元素变成列元素,列元素变成行元素

例如:

\begin{bmatrix} 1 &2 &3 &4 \\ 5&6 &7 &8 \\ 9 &10 &11 &12 \end{bmatrix}\rightarrow \begin{bmatrix} 1 &5 &9 \\ 2&6 &10 \\ 3&7 &11 \\ 4&8 &12 \end{bmatrix}

矩阵转置代码 

#include
#include
#include
#include//矩阵转置
double** Matrix_T(double** arr)
{if(arr==NULL)exit(-1);int row = (int)_msize(arr) / (int)sizeof(double*);int col = (int)_msize(*arr) / (int)sizeof(double);double** T = (double**)malloc(sizeof(double*) * col);int i = 0;int j = 0;if (T != NULL){for (i = 0; i < col; i++){T[i] = (double*)malloc(sizeof(double) * row);}}for (i = 0; i < col; i++){for (j = 0; j < row; j++){T[i][j] = arr[j][i];}}return T;
}

上述代码中:

  • 首先判断传入指针是否为空
  • 然后判断矩阵的维数,这部分在C语言判断矩阵维数中有详细讲解
  • 为转置后的矩阵开辟空间
  • 进行矩阵装置,行列互换传参 

上述方法使用的是malloc开辟的矩阵,该方法相对于用二维数组存储矩阵有以下几种优势:

1)函数传参时不用输入行列,只需传入指针

2)矩阵的大小可以未知,矩阵维数可以更改

3)不需要宏定义,程序可移植性高

malloc开辟矩阵的代码如下:

double** Make_Matrix(int row, int col)
{int i, j;double** arr = (double**)malloc(sizeof(double*) * row);if (arr != NULL){for (i = 0; i < row; i++){arr[i] = (double*)malloc(sizeof(double) * col);}}return arr;
}

该方法在C语言malloc开辟矩阵中有详细介绍。 

测试:

为了方便测试,再加入初始化矩阵和打印矩阵两个函数

初始化函数 

void Init_Matrix(double** arr)
{int i, j;int row = (int)_msize(arr) / (int)sizeof(double*);int col = (int)_msize(*arr) / (int)sizeof(double);for (i = 0; i < row; i++){for (j = 0; j < col; j++){arr[i][j] = pow(i,j);}}
}

 为了更加直观,让每个元素等于 i 的 j 次方

打印函数 

//打印矩阵
void print(double** arr)
{putchar('\n');int i, j, row, col;row = (int)_msize(arr) / (int)sizeof(double*);col = (int)_msize(*arr) / (int)sizeof(double);for (i = 0; i < row; i++){for (j = 0; j < col; j++){printf("%8.3lf ", arr[i][j]);}putchar('\n');}
}

主函数测试 

int main()
{int i = 3;int j = 5;double** arr = Make_Matrix(i, j);Init_Matrix(arr);double** res = Matrix_T(arr);printf("原矩阵:>");print(arr);printf("逆矩阵:>");print(res);return 0;
}

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...