斐波那契数列第N项f(N)[矩阵快速幂]
矩阵快速幂
定义矩阵A(m*n),B(p*q),A*B有意义当且仅当n=p。即A的列数等于B的行数。
且C=A*B,C(m*q)。
例如:

进入正题,由于现在全国卷高考不考矩阵,也没多大了解。因为遇到了斐波那契这题...
注意到: Fn+1=Fn+Fn-1
我们会有:

则:

所以我们只需要想办法求矩阵A的幂,这时候我们当然想要用快速幂。
代码部分:
定义矩阵:
struct matrix{
ll a[][];
};
(类比整数的快速幂)预处理:
[我们需要一类似于1的矩阵:]
『1 0 0
0 1 0
0 0 1』类似这种操作...
void init(){
int i,j;
memset(res.a,,sizeof res.a);
;i<=;i++) res.a[i][i]=;
][]=;
][]=;
][]=;
][]=;}
矩阵乘法:[就该题而言]
matrix mul(matrix p,matrix q){
int i,j,k;
matrix m;
memset(m.a,,sizeof m.a);
;i<=;i++)
;j<=;j++)
;k<=;k++)
m.a[i][j]=(m.a[i][j]+p.a[i][k]*q.a[k][j])%Mod;
return m;
}
快速幂:
void mfpow(ll p){
init();
while(p){
) res=mul(base,res);
base=mul(base,base);
p>>=;
}
}
全部的代码:(lowbee的难免会差一些,请大佬们见谅...)
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
typedef long long ll ;
inline ll read();
;
struct matrix{
ll a[][];
};
matrix res,base;
ll ans;
ll c[];
ll n;
namespace lys{
void init(){
int i,j;
memset(res.a,,sizeof res.a);
;i<=;i++) res.a[i][i]=;
][]=;
][]=;
][]=;
][]=;
}
matrix mul(matrix p,matrix q){
int i,j,k;
matrix m;
memset(m.a,,sizeof m.a);
;i<=;i++)
;j<=;j++)
;k<=;k++)
m.a[i][j]=(m.a[i][j]+p.a[i][k]*q.a[k][j])%Mod;
return m;
}
void mfpow(ll p){
init();
while(p){
) res=mul(base,res);
base=mul(base,base);
p>>=;
}
}
int main(){
int k;
n=read();
mfpow(n-);
c[]=;
c[]=;
;k<=;k++)
ans=(ans+res.a[][k]*c[k])%Mod;
cout<<ans<<endl;
;
}
}
int main(){
lys::main();
;
}
inline ll read(){
ll k=,f=;
char c=getchar();
'){
if(c=='-')
f=-;
c=getchar();
}
'){
k=k*+c-';
c=getchar();
}
return k*f;
}
题目链接[luogu]:
https://www.luogu.org/problem/show?pid=1962
斐波那契数列第N项f(N)[矩阵快速幂]的更多相关文章
- HDU4549 M斐波那契数列 —— 斐波那契、费马小定理、矩阵快速幂
题目链接:https://vjudge.net/problem/HDU-4549 M斐波那契数列 Time Limit: 3000/1000 MS (Java/Others) Memory Li ...
- 黑马入学基础测试(三)求斐波那契数列第n项,n<30,斐波那契数列前10项为 1,1,2,3,5,8,13,21,34,55
.获得用户的输入 计算 3打印就行了. 这里用到了java.util.Scanner 具体API 我就觉得不常用.解决问题就ok了.注意的是:他们按照流体的方式读取.而不是刻意反复 ...
- 斐波那契数列第n项的值及前n项之和
<script>// 算法题 // 题1:斐波那契数列:1.1.2.3.5.8.13.21...// // 一.斐波那契数列第n项的值 // // 方法一//递归的写法function a ...
- python练习题-打印斐波拉契数列前n项
打印斐波拉契数列前n项 #encoding=utf-8 def fibs(num): result =[0,1] for i in range(num-2): result. ...
- 经典算法详解(1)斐波那契数列的n项
斐波那契数列是一个常识性的知识,它指的是这样的一个数列,它的第一项是1,第二项是1,后面每一项都是它前面两项的和,如:1,1,2,3,5,8,13,21,34,55,89,144,233…… 说明:由 ...
- 用JS,求斐波那契数列第n项的值
<!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...
- 00.斐波那契数列第n项
# 斐波那契数列第n项 # 1 1 2 3 5 8 def fib(n): if n <= 2: return 1 else: return fib(n-2)+fib(n-1) def fib2 ...
- C#求斐波那契数列第30项的值(递归和非递归)
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- 51nod--1242 斐波那契数列第N项 (矩阵乘法优化)
题目: 1242 斐波那契数列的第N项 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 斐波那契数列的定义如下: F(0) = 0 F(1) = 1 F(n) ...
随机推荐
- MongoDB副本集模式安装
设备: 三个1G.20G.1核的虚拟机,系统是SentOS7 min 设置目录: Server1: mkdir -p /home/mongoshard/data/shard11 /home/mongo ...
- tp下的memcached运用
来源:http://blog.csdn.net/fudaoji/article/details/50722839 侵删 一.环境: lnmp开发服务器, memcached2.2.0,thinkp ...
- Microsoft Dynamics 365 之 味全食品 项目分享和Customer Engagement新特性分享
味全食品 Dynamics 365项目: 在企业门户和电子商务等新营销模式频出的今天,零售业需要利用统一的管理平台管理日益庞大的客户及销售数据,整合线上线下的零售业务,从采购.仓储.生产.配送到销售. ...
- 关于"设计模式“
夜深了,人静了,该写点儿东西了.这是第一篇博客,写点儿对设计模式的粗浅理解吧. 什么是设计模式? 上学那会儿初次听到这个名字一点儿概念都没有,不知道它是用来干嘛的,感觉听上去挺抽象的一个东西. 工 ...
- 201521123082 《Java程序设计》第14周学习总结
201521123082 <Java程序设计>第14周学习总结 标签(空格分隔):java 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. Answ ...
- 201521123053《Java课程设计》第七周学习总结
1. 本章学习总结 2. 书面作业 Q1. ArrayList代码分析 1.1 解释ArrayList的contains源代码 答:代码如下 public boolean contains(Objec ...
- 201521123121 《Java程序设计》第3周学习总结
本周学习总结 书面作业 代码阅读 public class Test1 { private int i = 1;//这行不能修改 private static int j = 2; public st ...
- 预防黑客入侵 防黑必学的cmd命令vs网络安全
这些命令又可*********三类:网络检测(如ping).网络连接(如telnet)和网络配置(如netsh).前面两种相对简单,本文只介绍两个网络配置工具.自带的关于网络的命令行工具很多,比如大家 ...
- Java课设-购物车系统
1.团队课程设计博客链接 /[博客链接]http://www.cnblogs.com/yayaya/p/7062197.html 2.个人负责模板或任务说明 1.建立Action类 2.购物车的属性 ...
- [js高手之路]Node.js+jade+mongodb+mongoose实现爬虫分离入库与生成静态文件
接着这篇文章[js高手之路]Node.js+jade抓取博客所有文章生成静态html文件继续,在这篇文章中实现了采集与静态文件的生成,在实际的采集项目中, 应该是先入库再选择性的生成静态文件.那么我选 ...