【洛谷P1939】 矩阵加速模板
https://www.luogu.org/problemnew/show/P1939
首先看一下斐波那契数列的矩阵快速幂求法:
有一个矩阵1*2的矩阵|f[n-2],f[n-1]|,要使它乘一个2*2的矩阵,使得到的矩阵为|f[n-1],f[n]|,即|f[n-1],f[n-2]+f[n-1]|
则该矩阵为
0 1
1 1
第一行第一列:f[n-2]*0+f[n-1]*1=f[n-1]
第一行第二列:f[n-2]*1+f[n-1]*1=f[n]
同理,对于本题:
有一个矩阵1*3的矩阵|f[n-3],f[n-2],f[n-1]|,要使它乘一个3*3的矩阵,使得到的矩阵为|f[n-2],f[n-1],f[n]|,即|f[n-2],f[n-1],f[n-3]+f[n-1]|
那么这个矩阵为
0 0 1
1 0 0
0 1 1
代码
#include<iostream>
#include<cstdio>
#include<algorithm>
#define ll long long
using namespace std;
const ll RQY = ;
ll t,n;
struct Matrix
{
ll m[][];
} A,ANS,One;
Matrix times(Matrix X,Matrix Y)
{
Matrix Ans;
for(int i=;i<=;i++)
for(int j=;j<=;j++)
Ans.m[i][j]=(X.m[i][]*Y.m[][j]%RQY+X.m[i][]*Y.m[][j]%RQY+X.m[i][]*Y.m[][j]%RQY)%RQY;
return Ans;
}
Matrix qpow(Matrix X,ll k)
{
Matrix S=One;
while(k)
{
if(k&) S=times(S,X);
k>>=;
X=times(X,X);
}
return S;
}
int main()
{
scanf("%lld",&t);
One.m[][]=;
One.m[][]=;
One.m[][]=;
A.m[][]=;
A.m[][]=;
A.m[][]=;
A.m[][]=;
while(t--)
{
scanf("%lld",&n);
n-=;
ANS=qpow(A,n);
printf("%lld\n",(ANS.m[][]+ANS.m[][]+ANS.m[][])%RQY);
}
}
【洛谷P1939】 矩阵加速模板的更多相关文章
- 洛谷 P1939 矩阵加速(数列)
		
题意简述 \(a[1]=a[2]=a[3]=1\) \(a[x]=a[x−3]+a[x−1](x>3)\) 求a数列的第n项对1000000007取余的值. 题解思路 矩阵加速 设\[ F=\b ...
 - 洛谷 [P1939] 矩阵加速数列
		
矩阵快速幂模版 #include <iostream> #include <cstring> #include <cstdlib> #include <alg ...
 - 【洛谷P3369】【模板】普通平衡树题解
		
[洛谷P3369][模板]普通平衡树题解 题目链接 题意: 您需要写一种数据结构(可参考题目标题),来维护一些数,其中需要提供以下操作:1. 插入x数2. 删除x数(若有多个相同的数,因只删除一个)3 ...
 - 洛谷 P1939 【模板】矩阵加速(数列) 解题报告
		
P1939 [模板]矩阵加速(数列) 题目描述 a[1]=a[2]=a[3]=1 a[x]=a[x-3]+a[x-1] (x>3) 求a数列的第n项对1000000007(10^9+7)取余的值 ...
 - [洛谷P1939]【模板】矩阵加速(数列)
		
题目大意:给你一个数列a,规定$a[1]=a[2]=a[3]=1$,$a[i]=a[i-1]+a[i-3](i>3)$求$a[n]\ mod\ 10^9+7$的值. 解题思路:这题看似是很简单的 ...
 - 【洛谷4721】【模板】分治FFT(CDQ分治_NTT)
		
题目: 洛谷 4721 分析: 我觉得这个 "分治 FFT " 不能算一种特殊的 FFT ,只是 CDQ 分治里套了个用 FFT (或 NTT)计算的过程,二者是并列关系而不是偏正 ...
 - 【洛谷3865】 【模板】ST表(猫树)
		
传送门 洛谷 Solution 实测跑的比ST表快!!! 这个东西也是\(O(1)\)的,不会可以看我上一篇Blog 代码实现 代码戳这里
 - 洛谷P1939【模板】矩阵加速(数列)+矩阵快速幂
		
思路: 这个 a[1]=a[2]=a[3]=1 a[x]=a[x-3]+a[x-1] (x>3) 可以想成: [a(n) ] [1 0 1] [a(n-1) ] [a(n-1) ] = ...
 - 洛谷 P1939 【模板】矩阵加速(数列)
		
题目描述 a[1]=a[2]=a[3]=1 a[x]=a[x-3]+a[x-1] (x>3) 求a数列的第n项对1000000007(10^9+7)取余的值. 输入输出格式 输入格式: 第一行一 ...
 
随机推荐
- VMware Workstation 12.5.9 Pro虚拟机软件中文版
			
更新为 VMware Workstation 12.5.9 pro版.VMware虚拟机软件无疑是windows系统下最强大好用的虚拟机软件.最新的VMware Workstation 12 Pro ...
 - Vue.js-----轻量高效的MVVM框架(八、使用组件)
			
什么是组件? 组件(Component)是 Vue.js 最强大的功能之一.组件可以扩展 HTML 元素,封装可重用的代码.在较高层面上,组件是自定义元素,Vue.js 的编译器为它添加特殊功能.在有 ...
 - ES6多行字符串+模板字符串
			
多行字符串 最新的ES6标准新增了一种多行字符串的表示方法,用反引号 ` ... ` 表示: 'use strict'; // 如果浏览器支持模板字符串,将会替换字符串内部的变量: var name ...
 - Notepad++实用插件
			
说明: Converter: 编码转换工具,ascii2hex,hex2ascii DoxyIt: 添加文件或者函数注释比较方便 DSpellCheck: 拼写检查 MIME Tools: 将Base ...
 - RTT之内核服务函数
			
一 延时函数: rt_thread_delay(t) //调用时进入系统调度. rt_kprintf()函数在kservice.c中实现,如果不使用设备驱动,则由自定义函数void rt_hw_con ...
 - visual stdio使用
			
现在转换使用visual stdio,因为很多和以前的快捷键不同,也不打算换了,这样可移动性应该更好吧. 1.注释代码, 首先按下ctrl + k,然后再按下ctrl + c 2.取消注释,首先按下c ...
 - 快速排序算法的实现 && 随机生成区间里的数 && O(n)找第k小 && O(nlogk)找前k大
			
思路:固定一个数,把这个数放到合法的位置,然后左边的数都是比它小,右边的数都是比它大 固定权值选的是第一个数,或者一个随机数 因为固定的是左端点,所以一开始需要在右端点开始,找一个小于权值的数,从左端 ...
 - cad 安装失败/出错/卸载 2018/2017/2016/2015/2013/2012
			
AUTO Uninstaller 更新下载地址 1.选择CAD 2.选择版本 3.点击“开始卸载”
 - PHP会话管理
			
Session使用 在每个页面中使用session之前,必须使用session_start() 在每个session中都可以使用$_SESSION这个全局数组,在页面必须调用session_start ...
 - Murano Weekly Meeting 2016.05.17
			
Meeting time: 2016.May.17 1:00~2:00 Chairperson: Kirill Zaitsev, from Mirantis Meeting summary: 1 ...