第一章、线性代数(1)矩阵乘法

一、矩阵相关概念

【矩阵】

由n×m个数排成n行m列的数表称为n行m列的矩阵,简称n×m矩阵。记作:

在学习图论时,存储图的一种方式------邻接矩阵,就是矩阵。所以矩阵用二维数组就可以存储。

【特殊的矩阵】

1、方阵

行数等于列数的矩阵称为方阵。方阵中行数等于列数的元素构成主对角线。

2、三角矩阵

如果方阵主对角线左下方的元素均为0,称为上三角矩阵。例如:

如果方阵主对角线右上方的元素均为0,称为下三角矩阵。例如:

3、对角矩阵

主对角线之外的元素均为0的方阵称为对角矩阵。例如:

4、单位矩阵

主对角线的元素均为1的对角矩阵。例如:

【矩阵的运算】

1、加法、减法和数乘

两个矩阵的加减法为对应元素分别作加减法。注意:只有同型矩阵之间可以做对应相加减!

数乘即为矩阵乘以一个数,结果为矩阵中每个元素都乘以这个数。

矩阵的加减与数乘称为矩阵的线性运算。

2、矩阵乘法

矩阵相乘时只有第一个矩阵的列数第二个矩阵的行数相同时才有意义!

设A为n×s的矩阵,B为s×m的矩阵,那么矩阵A与矩阵B的乘积为n×m的矩阵C,其中cij表示矩阵A的第i行与矩阵B的第j列元素分别相乘再相加。

【矩阵的运算规律】

1、线性运算满足交换律、结合律、分配律

·A+B = B+A

·A+B+C = A+(B+C)

·k*(A+B)= k*A + k*B

2、矩阵乘法只满足结合律和分配律

·ABC = A(BC)

·A(B+C) = AB + AC

注意:矩阵乘法可能不满足交换律。因此,在计算矩阵乘法时,前后顺序很重要!

特殊的,任何矩阵乘单位矩阵E,都不会改变:AE = EA = A 。因此,单位矩阵相当于数字1。

二、【模板】矩阵乘法

cpp 复制代码
#define  _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
using namespace std;

const int N = 110;

int n, m, s;
int a[N][N], b[N][N], c[N][N];

int main()
{
	cin >> n >> m >> s;

	for (int i = 1;i <= n;i++)
		for (int j = 1;j <= m;j++)
			cin >> a[i][j];

	for (int i = 1;i <= m;i++)
		for (int j = 1;j <= s;j++)
			cin >> b[i][j];

	for (int i = 1;i <= n;i++)
	{
		for (int j = 1;j <= s;j++)
		{
			for (int k = 1;k <= m;k++)
			{
				c[i][j] += a[i][k] * b[k][j];
			}
		}
	}

	for (int i = 1;i <= n;i++)
	{
		for (int j = 1;j <= s;j++)
		{
			cout << c[i][j] << " ";
		}
		cout << endl;
	}

	return 0;
}

三、【模板】矩阵快速幂

cpp 复制代码
#define  _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include <cstring>
using namespace std;

typedef long long LL;
const int N = 110, mod = 1e9 + 7;

LL k, n;

// 矩阵的结构体
struct matrix
{
	LL m[N][N];

	// 构造函数
	matrix()
	{
		memset(m, 0, sizeof m);
	}

	// 重载乘法运算符
	matrix operator*(const matrix& B) const
	{
		matrix C;
		for (int i = 1;i <= n;i++)
		{
			for (int j = 1;j <= n;j++)
			{
				for (int k = 1;k <= n;k++)
				{
					C.m[i][j] = (C.m[i][j] + m[i][k] * B.m[k][j]) % mod;
				}
			}
		}
		return C;
	}

}A, RET;

void qpow(LL b)
{
    // 把RET变为单位矩阵
	for (int i = 1;i <= n;i++)
		RET.m[i][i] = 1;

	while (b)
	{
		if (b & 1)
		{
			RET = RET * A;
		}

		b >>= 1;
		A = A * A;
	}
}

int main()
{
	cin >> n >> k;
	for (int i = 1;i <= n;i++)
		for (int j = 1;j <= n;j++)
			cin >> A.m[i][j];

	qpow(k);

	for (int i = 1;i <= n;i++)
	{
		for (int j = 1;j <= n;j++)
		{
			cout << RET.m[i][j] << " ";
		}
		cout << endl;
	}

	return 0;
}

四、【练习】矩阵加速

解法:利用矩阵快速幂加速递推,构造出矩阵相乘的形式。

cpp 复制代码
#define  _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include <cstring>
using namespace std;

typedef long long LL;
const int N = 5, mod = 1e9 + 7;

struct matrix
{
	LL m[N][N];

	matrix()
	{
		memset(m, 0, sizeof m);
	}

	matrix operator*(const matrix& B) const
	{
		matrix C;
		for (int i = 1;i <= 3;i++)
		{
			for (int j = 1;j <= 3;j++)
			{
				for (int k = 1;k <= 3;k++)
				{
					C.m[i][j] = (C.m[i][j] + m[i][k] * B.m[k][j]) % mod;
				}
			}
		}
		return C;
	}

	void clear()
	{
		memset(m, 0, sizeof m);
	}

}A, RET;

void qpow(LL b)
{
	RET.m[1][1] = RET.m[1][2] = RET.m[1][3] = 1;
	A.m[1][1] = A.m[1][2] = A.m[2][3] = A.m[3][1] = 1;

	while (b)
	{
		if (b & 1)
			RET = RET * A;

		b >>= 1;
		A = A * A;
	}
}

int main()
{
	int T;
	cin >> T;
	while (T--)
	{
		int n;
		cin >> n;

		A.clear();
		RET.clear();

		if (n == 1 || n == 2 || n == 3)
		{
			cout << 1 << endl;
			continue;
		}

		qpow(n - 3);

		cout << RET.m[1][1] << endl;
	}

	return 0;
}
相关推荐
zhangfeng113316 小时前
光驱动的 AI 算力卡,也就是光子计算(Photonic Computing)芯片,用光子(光)代替电子来做矩阵乘法和数据传输
人工智能·语言模型·矩阵·架构·transformer·芯片
会Tk矩阵群控的小木18 小时前
小红书矩阵系统2026最新技术架构与多账号自动化运营实战
运维·矩阵·架构·自动化·个人开发
Eloudy1 天前
光子的单缝衍射模型
线性代数·机器学习·概率论
2601_957884841 天前
面向内容合规性的短视频矩阵分发机制:感知哈希去重与语义检索优化实践
矩阵·音视频·哈希算法
2601_957787581 天前
异构网络媒体中台的容灾与安全架构:分布式资产生命周期、零信任网关与跨域路由实践
人工智能·矩阵
2601_957879332 天前
基于LBS位置服务与跨域OpenAPI的同城矩阵系统:边缘裂变与数据网关架构实践
线性代数·矩阵·架构
lqjun08272 天前
Hessian 矩阵(海森矩阵)及其应用
线性代数·矩阵
2601_957884842 天前
分布式媒体矩阵系统的任务调度架构:高并发分发队列与背压控制控制实践
分布式·矩阵·媒体
AI科技星2 天前
依托Gε₀ = e²/(4παmₚ²)核心方程:全新公式推导+原创理论提炼+全维度精算验证
人工智能·线性代数·架构·概率论·学习方法
ZHANG8023ZHEN2 天前
斜方差矩阵Cholesky参数化
线性代数·矩阵