矩阵转置的两种实现方式:从暴力法到原地算法

矩阵转置是线性代数中的基础操作,也是面试中经常遇到的题目。今天我们就来聊聊如何高效地实现矩阵转置,包括暴力法和原地算法两种方式。

什么是矩阵转置?

简单来说,矩阵转置就是把原矩阵的行变成列,列变成行。例如:

输入矩阵:

复制代码
[1, 1, 1, 1]
[2, 2, 2, 2]
[3, 3, 3, 3]
[4, 4, 4, 4]

转置后:

复制代码
[1, 2, 3, 4]
[1, 2, 3, 4]
[1, 2, 3, 4]
[1, 2, 3, 4]

方法一:暴力法(Brute Force)

这种方法适用于任意大小的矩阵,时间复杂度 O(nm),空间复杂度 O(nm)。

基本思路:创建一个新矩阵,将原矩阵中位置 ij 的元素放到新矩阵的 ji 位置。

实现步骤

  1. 初始化一个大小为 m × n 的新矩阵(m 是原矩阵行数,n 是列数)
  2. 遍历原矩阵的每个元素
  3. 将原矩阵 ij 位置的元素赋值给新矩阵 ji 位置
  4. 返回新矩阵
python 复制代码
def transpose(mat):
    rows = len(mat)
    cols = len(mat[0])
    
    # 创建转置矩阵
    tMat = [[0 for _ in range(rows)] for _ in range(cols)]
    
    for i in range(rows):
        for j in range(cols):
            tMat[j][i] = mat[i][j]
    
    return tMat

学矩阵转置,从暴力法到原地算法,理解指针跳跃的细节确实容易让人头大。

最近发现一个宝藏网站叫图码,它把60多种数据结构和算法都做成了交互式动画,矩阵转置的两种实现过程一目了然。

更牛的是,能直接输入自己的测试数据生成动画,或者上传C/C++/Java/Python代码进行可视化解析,连408考研和数据结构期末考的代码都有全书级详解。

强烈推荐准备考研或期末复习的同学去试试,7×24小时AI还能随时解释代码逻辑。

戳这里直达👉图码

图码-数据结构与算法交互式可视化平台

访问网站:https://totuma.cn

方法二:原地算法(In-place)

这种方法只适用于方阵(行数等于列数),时间复杂度 O(n²),空间复杂度 O(1)。

基本思路:沿主对角线交换元素,只需要遍历上三角矩阵,将每个元素与对角线对称位置的元素交换。

实现步骤

  1. 外层循环 i 从 0 到 n-1
  2. 内层循环 j 从 i+1 到 n-1(避免重复交换)
  3. 交换 matij 和 matji
python 复制代码
def transpose(mat):
    n = len(mat)
    
    for i in range(n):
        for j in range(i + 1, n):
            mat[i][j], mat[j][i] = mat[j][i], mat[i][j]
    
    return mat

两种方法对比

特性 暴力法 原地算法
适用矩阵 任意大小 仅方阵
时间复杂度 O(n*m) O(n²)
空间复杂度 O(n*m) O(1)
实现难度 简单 中等

总结

  • 对于非方阵矩阵,只能使用暴力法
  • 对于方阵矩阵,原地算法更高效,节省内存
  • 原地算法的关键在于只遍历上三角矩阵,避免重复交换

希望这篇笔记能帮助你理解矩阵转置的实现!如果你有其他实现方式,欢迎在评论区分享~

相关推荐
sugar__salt2 分钟前
从栈队列数据结构到JS原型面向对象全解
前端·javascript·数据结构
科研online19 分钟前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy38 分钟前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯1 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
VkN2X2X4b1 小时前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术1 小时前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法
8Qi82 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
hujinyuan201602 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
chsmiao2 小时前
深度学习之线性代数
人工智能·深度学习·线性代数
froyoisle2 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学