个人已知的线性代数科技
本文比较杂,涉及多方面
#1 矩阵
*1 矩阵乘法
通常而言,矩阵乘法是用于实现线性变换的一种工具,一般将一个对象矩阵乘上变换矩阵就可以实现线性变换或者某一阶段的线性变换。而信息学中则利用了矩阵乘法的结合律,从而实现了快速变换的过程。
例题
现在给定一个数列的线性递推式:
(斐波那契数列)
solution
可以构造初始状态矩阵:
以及转移矩阵:
然后设
根据转移方式不难发现实际上
然后因为矩阵乘法具有结合律,那么可以先把
给计算出来,再来计算 至于如何快速计算
,可以模仿快速幂算法一样,时间复杂度是迭代次数乘以矩阵乘法的时间,即:
~
所以矩阵在处理这种线性转移的问题的时候能够成为非常合适的一类工具。
*2 广义矩阵乘法
对于更多问题而言,其计算过程并不是简单的矩阵乘法,而有可能是加权取最值,按位异或、与、或等,但是只要其转移是线性的,那么依旧可以使用矩阵来进行求解,如果这个转移满足结合律,那么他甚至可以用类似的方法优化成
例题
给定一张带权有向图,问经过恰好
条边后从节点 到达节点 的最短路是多少
solution
同样可以构造初始矩阵
满足 表示从节点 走到节点 的最短路是多少,然后转移矩阵就是类似于 算法中的一样,而转移方式也是同 算法一样,因为不难证明这个是具有结合律而却是线性的
#2 高斯消元
其实就是解多元线性方程组,形式如
然后就是模拟算法吧,模拟小学生解方程一样:
代码如下
#include <bits/stdc++.h> #define int long long using namespace std; inline int read(){ int x=0,f=1;char ch=getchar(); while(!isdigit(ch))f^=(ch=='-'),ch=getchar(); while(isdigit(ch))x=(x<<3)+(x<<1)+(ch^48),ch=getchar(); return f?x:-x; } double a[115][115],ans[115]; int n; int Gauss(){ for(int k=1;k<=n;k++){ int notpossible=1; for(int i=1;i<=n-k+1;i++){ if(a[i][k]!=0){ swap(a[i],a[1]); notpossible=0; break; } } if(notpossible)return 1; for(int i=1;i<=n-k+1;i++){ if(a[i][k]!=0){ for(int j=n+1;j;j--) a[i][j]/=a[i][k]; } } for(int i=2;i<=n-k+1;i++){ if(a[i][k]!=0){ for(int j=1;j<=n+1;j++) a[i][j]-=a[1][j]; } } swap(a[1],a[n-k+1]); } for(int k=n;k;k--){ int i=n-k+1; ans[k]=a[i][n+1]; for(int j=n;j>k;j--) ans[k]-=a[i][j]*ans[j]; } return 0; } signed main(){ n=read(); for(int i=1;i<=n;i++){ for(int j=1;j<=n+1;j++){ scanf("%lf",&a[i][j]); } } int k=Gauss(); if(k)printf("No Solution"); else{ for(int i=1;i<=n;i++){ printf("%.2lf\n",ans[i]); } } }
其实高斯消元在取模意义下依然可以成立,前提是逆元存在
#3 行列式
行列式是一类类似于求解生成排列加权的计数工具,目前并不常见(算法里头好像就是Matrix-Tree定理
用到过,其他的就算出题了也不会做)
定义方阵
计算方法:
使用高斯消元将
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效