矩阵模板
1.并查集模板2.求质因数模板3.二分图最大匹配模板(匈牙利算法)4.欧拉函数模板5.ST表模板6.快速幂模板7.字典树模板
8.矩阵模板
9.Dijkstra单源最短路模板10.最近公共祖先模板(LCA)11.拓扑排序模板12.区间素数筛模板13.Kruskal和Prim模板14.树状数组模板15.二维坐标离散化模板16.单点修改区间查最值-树状数组模板17.KMP模板18.二叉搜索树模板19.DIjkstra进阶模板 路径记录 按权重(结点数最小等)记录20.判断负环模板21.Exgcd 模板22.压位高精度模板23.线段树模板24.扫描线模板25.莫队模板26.带修莫队模板27.SCC缩点模板28.取模+组合数29.FFT 高精度乘法模板30.字符串自然溢出哈希/单哈希/双哈希模板31.树模板32.dsu on tree 模板33.线段树模板重制34.主席树模板35.大数质因数分解模板36.线段树合并模板37.int128输入输出流38.Meissel_Lehmer模板39.浮点高精度40.自适应辛普森法41.unordered_map随机底数种子struct Matrix { i64 N; vector<vector<i64>> A; Matrix() { N = 0;} Matrix(int n) { N = n; A.resize(N + 1); for (int i = 0; i <= N; i ++) A[i].resize(N + 1, 0); } void init(vector<vector<i64>> a, int n) { A = a; N = n; } Matrix operator*(const Matrix &b) const { Matrix res(b.N); for (int i = 1; i <= b.N; ++i) for (int j = 1; j <= b.N; ++j) for (int k = 1; k <= b.N; ++k) res.A[i][j] = (res.A[i][j] + A[i][k] * b.A[k][j]); return res; } Matrix qpow(i64 k) { Matrix res(N); //斐波那契数列初始化 //res.A[1][1] = res.A[1][2] = 1; //A[1][1] = A[1][2] = A[2][1] = 1; //单位矩阵 for (int i = 0; i <= N; i ++) res.A[i][i] = 1; while (k) { if (k & 1) res = res * (*this); (*this) = (*this) * (*this); k >>= 1; } return res; } //求行列式 i64 det() { return DET(A, N); } i64 DET(vector<vector<i64>> arr1, int n) { i64 sum = 0; //i是第一行的列指标,M是余子式的值,sum是行列式的计算值 if (n == 1)//一阶行列式直接得出结果 return arr1[0][0]; else if (n > 1) { for (int i = 0; i < n; i++) { //按照第一行展开 i64 M = Minor(arr1, i, n); sum += pow(-1, i + 2) * arr1[0][i] * M; } } return sum; } i64 Minor(vector<vector<i64>> arr1, int i, int n) { vector arr2(n + 1, vector<i64>(n + 1)); //以下为构造余子式的过程。 for (int j = 0; j < n - 1; j++) { for (int k = 0; k < n - 1; k++) { if (k < i) arr2[j][k] = arr1[j + 1][k]; else if (k >= i) arr2[j][k] = arr1[j + 1][k + 1]; } } return DET(arr2, n - 1); //构造完后,余子式是一个新的行列式,返回DET函数进行计算。 } };
本文作者:Ke_scholar
本文链接:https://www.cnblogs.com/Kescholar/p/17877365.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步