数学知识——矩阵乘法
创始人
2025-05-28 14:41:06
0

矩阵乘法

文章目录

  • 矩阵乘法
    • 引入
    • 例题
      • 斐波那契前 n 项和
        • 思路
        • 代码
      • 佳佳的斐波那契
        • 思路
        • 代码

引入

由于线性递推式可以表示成矩阵乘法的形式,也通常用矩阵快速幂来求线性递推数列的某一项。
利用结合律,矩阵乘法可以利用 快速幂 的思想来优化。

例题

斐波那契前 n 项和

大家都知道 Fibonacci 数列吧,f1=1,f2=1,f3=2,f4=3,…,fn=fn−1+fn−2。

现在问题很简单,输入 n 和 m,求 fn 的前 n 项和 Snmodm。

输入格式
共一行,包含两个整数 n 和 m。

输出格式
输出前 n 项和 Snmodm 的值。

数据范围
1≤n≤2000000000
,
1≤m≤1000000010
输入样例:
5 1000
输出样例:
12

思路

已知递推公式Sn+1=Sn+fn+1S_{n + 1} = S_n + f_{n + 1}Sn+1​=Sn​+fn+1​,对于求Sn+1S_{n + 1}Sn+1​我们要知道Sn和fn+1S_n和f_{n + 1}Sn​和fn+1​。
构造矩阵Fn=[fn,fn+1,Sn]F_n = [f_n, f_{n + 1}, S_n]Fn​=[fn​,fn+1​,Sn​]。
对于Fn+1=[fn+1,fn+2,Sn+1]F_{n + 1} = [f_{n + 1}, f_{n + 2}, S_{n + 1}]Fn+1​=[fn+1​,fn+2​,Sn+1​]等于FnF_nFn​与矩阵A=[[0,1,0],[1,1,1],[0,0,1]]A = [[0, 1, 0], [1, 1, 1], [0, 0, 1]]A=[[0,1,0],[1,1,1],[0,0,1]]相乘,
对于Fn=F1∗An−1F_n = F_1 * A^{n - 1}Fn​=F1​∗An−1

代码

from copy import deepcopy
N = 3
F1 = [[0] * N for _ in range(N)]
F1[0] = [1, 1, 1]
A = [[0, 1, 0], [1, 1, 1], [0, 0, 1]]def mul(a, b) :tmp = [[0] * N for _ in range(N)]for i in range(N) : # i行for j in range(N) : # j列for k in range(N) :tmp[i][j] = (tmp[i][j] + a[i][k] * b[k][j]) % mreturn tmpdef qmi(a, k) :res = deepcopy(F1)while k :if k & 1 :res = mul(res, a)k >>= 1a = mul(a, a)return res
n, m = map(int, input().split())
res = qmi(A, n - 1)
print(res[0][2])

佳佳的斐波那契

佳佳对数学,尤其对数列十分感兴趣。

在研究完 Fibonacci 数列后,他创造出许多稀奇古怪的数列。

例如用 S(n) 表示 Fibonacci 前 n项和 modm
的值,即 S(n)=(F1+F2+…+Fn)modm,其中 F1=F2=1,Fi=Fi−1+Fi−2。

可这对佳佳来说还是小菜一碟。

终于,她找到了一个自己解决不了的问题。

用 T(n)=(F1+2F2+3F3+…+nFn)modm 表示 Fibonacci 数列前 n 项变形后的和 modm 的值。

现在佳佳告诉你了一个 n 和 m,请求出 T(n) 的值。

输入格式
共一行,包含两个整数 n 和 m。

输出格式
共一行,输出 T(n) 的值。

数据范围
1≤n,m≤2^31−1
输入样例:
5 5
输出样例:
1
样例解释
T(5)=(1+2×1+3×2+4×3+5×5)mod5=1

思路

Tn+1=Tn+(n+1)∗fn+1T_{n + 1}= T_n + (n +1)* f_{n + 1}Tn+1​=Tn​+(n+1)∗fn+1​,矩阵乘法要使用快速幂推导,等式必须是线性的,也就是保证转移矩阵中只有常数。
对于求取TnT_nTn​,必须构造一个线性的递推公式(必须包含TnT_nTn​)的函数。
对于Pn=nSn−TnP_{n} = nS_n - T_nPn​=nSn​−Tn​有这样的递推公式Pn+1=Pn+SnP_{n + 1} = P_n + S_nPn+1​=Pn​+Sn​
构造Fn=[fn,fn+1,Sn,Pn]F_n = [f_n, f_{n + 1}, S_n, P_n]Fn​=[fn​,fn+1​,Sn​,Pn​],Fn+1=[fn+1,fn+2,Sn+1,Pn+1]F_{n + 1} = [f_{n + 1}, f_{n + 2}, S_{n + 1}, P_{n + 1}]Fn+1​=[fn+1​,fn+2​,Sn+1​,Pn+1​],
转移矩阵为A=[[0,1,0,0],[1,1,1,0],[0,0,1,1],[0,0,0,1]]A = [[0, 1, 0, 0], [1, 1, 1, 0], [0, 0, 1, 1], [0, 0, 0, 1]]A=[[0,1,0,0],[1,1,1,0],[0,0,1,1],[0,0,0,1]]
Fn=F1∗An−1F_n = F_1* A^{n - 1}Fn​=F1​∗An−1

代码

from copy import deepcopy
N = 4
F1 = [[0] * N for _ in range(N)]
F1[0] = [1, 1, 1, 0]
A = [[0, 1, 0, 0], [1, 1, 1, 0], [0, 0, 1, 1],[0, 0, 0, 1]]
def mul(a, b) :tmp = [[0] * N for _ in range(N)]for i in range(N) :for j in range(N) :for k in range(N) :tmp[i][j] = (tmp[i][j] + a[i][k] * b[k][j]) % mreturn tmpdef qmi(a, k) :res = deepcopy(F1)while k :if k & 1 :res = mul(res, a)k >>= 1a = mul(a, a)return resn, m = map(int, input().split())
res = qmi(A, n - 1)
print((n * res[0][2] - res[0][3]) % m)

相关内容

热门资讯

刚刚,大跳水!超42万人爆仓!... 来源:券商中国 加密货币,遭遇抛售潮! 凯文·沃什被提名为下一任美联储主席所产生的后续效应,正持续波...
做好银行网点“加减法” 国家金融监督管理总局网站披露的信息显示,2025年共有约1.1万家银行业金融机构的线下网点获准退出,...
金价暴跌引热议,网友:商场门口... 来源:中国基金报 随着国际金价急速下跌,国内首饰金价也迎来大幅回调。 1月31日,老庙报1546元/...
内蒙古一银行员工将储户220万... 内蒙古一银行员工将储户220万元存款转走并挥霍,银行称员工已离岗不愿承担赔偿 1月31日,有媒体报...
老年医学科进修轶事|老年医学如... 和年苑,北京协和医院老年医学科公众号,传递老年医学的价值和声音 在这里,了解当代老年医学 Autum...
和讯投顾余兴栋:周五杀跌,下周... 周五大盘大幅度的杀跌又探底回升,收出一根长长的下影线,不少的朋友又在问我,那这根k线是不是就意味着调...
【数智周报】马化腾评豆包手机;... 【数智周报将整合本周最重要的企业级服务、云计算、大数据领域的前沿趋势、重磅政策及行研报告。】 观点马...
和美字节,用字节连接和美 和美字节(Hemei Byte),是杭州桑桥网络科技有限公司于 2026 年 1 月完成品牌升级后启...
仙乐健康56岁副总姚壮民业务员... 瑞财经 刘治颖 1月29日,仙乐健康科技股份有限公司(以下简称:仙乐健康)向港交所主板递交上市申请书...
詹姆斯下家概率:骑士最高退役第... 近日,有关詹姆斯的未来引发了大众的热议,相关机构也更新了这位巨星的下家概率,回归骑士是最大可能。 相...
原创 猛... 在国际金价屡创历史新高之时,资本市场正经历一场有趣的分化:有人急于套现离场,有人却大举加码。近日,一...
原创 男... 在爱情的海洋中,星座与情感交织出无数动人的故事。当一个男性用以下这四个称呼来称呼你时,他的爱情之舟正...
民航持续回暖:南航、海航预计去... 时隔五年,南航预计在三大航中率先实现年度扭亏。 截至1月30日晚间,中国国航(601111.SH)、...
公募加仓非银金融,后市机会如何... 基金增配保险、券商股。 最新数据显示,公募基金2025年四季度的非银金融仓位提高1个百分点。继有色金...
赵慧芳主任中医治疗产后“月子病... 赵慧芳主任中医治疗产后“月子病”的临床智慧 产后调理是中华民族传承千年的养生智慧,在中医理论中占据重...
江西万年青水泥股份有限公司20... 本公司及董事会全体成员保证信息披露的内容真实、准确、完整,没有虚假记载、误导性陈述或重大遗漏。 一、...
科学应对甲状腺结节,别让“结节... 随着健康意识的提升 超声检查在体检中普及率不断提高 甲状腺结节的检出率也显著上升 不少人拿着“结节”...
春节前,政府债发行提速 来源:郁言债市 01 1月资金面,两轮波动,中枢平稳 回顾开年以来资金利率走势,月内资金经历两轮波动...
【央行多措并举护航,专家预期节... 【央行多措并举护航,专家预期节前流动性保持充裕】1月29日,中国人民银行以固定利率、数量招标方式开展...
季节性因素叠加市场需求不足,1... 来源:界面新闻 记者 辛圆 国家统计局周六公布数据显示,1月份,中国制造业采购经理人指数(PM...