题目

  Winder最近在学习fibonacci 数列的相关知识。我们都知道fibonacci数列的递推公式是F(n)=F(n-1)+F(n-2)(n>=2 且n 为整数)。 Winder想知道的是当我们将这个递推式改为F(n)=AF(n-1)+BF(n-2)(n>=2且n为整数)时我们得到的是怎样的数列。但是,Winder很懒,所以只能由你来帮他来完成这件事。 注意,这里我们依然令F(0)=F(1)=1。

★数据输入

  输入第一行三个正整数N,A 和B(N<=10;1<=A、B<=100 且均为整数)。 接下来有N 行,每行一个自然数n(n<=100000000)。

★数据输出

  输出一行一个整数F(n),由于结果可能会很大,Winder要求输出结果对2013取模。

输入示例 输出示例

5 4 5

2

4

8

16

32

9

209

1377

182

9

题解:

  一道很经典的矩阵快速幂裸题。

  首先讲解快速幂,当我们需要求$a^{b}$对mod取模时,可以将b转化为2进制,就可以将b转换为若干个二次幂之和。例如,我们在计算2的12次方时,12的二进制为1100,1100中的两个1的位权分别为4和8,因此$2^{12}$次方便可以转换为$2^{4}*2^{8}$。由此,我们先将答案ans赋值为1,只需要计算a的1,2,4,8.....次方,然后看一下b在该位的数值是否为1即可,如果为1,将ans乘上即可。

快速幂的代码如下

  1. ll fastpow(ll a,ll b)
  2. {
  3. ll ans=;
  4. while(b)
  5. {
  6. if(b&) ans=ans*a%mod;
  7. a=a*a%mod;
  8. b>>=;
  9. }
  10. return ans;
  11. }

  接下来回到本题,由于n的数字较大,加上取模速度较慢,本题递归递推会超时。因此需要寻找复杂度小于O(n)的算法。

  由于

$
\left(
\begin{matrix}
a & b \\
1 & 0 
\end{matrix}
\right)*
\binom{f(n)}{f(n-1)}=\binom{f(n+1)}{f(n)}
$我们可以构造矩阵,可以得到

$$
\left(
\begin{matrix}
a & b \\
1 & 0
\end{matrix}
\right) \tag{2}^{n-1}*
\binom{f(1)}{f(0)}=\binom{f(n)}{f(n-1)}
$$

由此,我们只需要计算矩阵

$$
\left(
\begin{matrix}
a & b \\
1 & 0
\end{matrix}
\right)
$$

的n-1次方即可,对于这个矩阵的n-1次方,使用快速幂求出所求矩阵,便可以在$\log n$的时间内计算出f(n)的值。

  1. #include<iostream>
    #include<cstdio>
  2. #include<algorithm>
  3. #include<cmath>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<string>
  7. #include<vector>
  8. #include<queue>
  9. #include<set>
  10. using namespace std;
  11. typedef long long ll;
  12. typedef long double ld;
  13. typedef unsigned long long ull;
  14. typedef pair <int,int> pii;
  15. #define rep(i,x,y) for(int i=x;i<y;i++)
  16. #define rept(i,x,y) for(int i=x;i<=y;i++)
  17. #define per(i,x,y) for(int i=x;i>=y;i--)
  18. #define pb push_back
  19. #define fi first
  20. #define se second
  21. #define mes(a,b) memset(a,b,sizeof a)
  22. const int inf=0x3f3f3f3f;
  23. const int mod=;
  24. class matrix
  25. {
  26. public:
  27. int arrcy[][];//arrcy为矩阵,下表从0开始
  28. int row,column;//row为矩阵的行,column为矩阵的列
  29. friend matrix operator *(matrix s1,matrix s2)
  30. {
  31. int i,j;
  32. matrix s3;
  33. for (i=;i<s1.row;i++)
  34. {
  35. for (j=;j<s2.column;j++)
  36. {
  37. for (int k=;k<s1.column;k++)
  38. {
  39. s3.arrcy[i][j]+=s1.arrcy[i][k]*s2.arrcy[k][j];
  40. s3.arrcy[i][j]%=mod;
  41. }
  42. }
  43. }
  44. s3.row=s1.row;
  45. s3.column=s2.column;
  46. return s3;
  47. }
  48. };
  49. matrix quick_pow(matrix s1,long long n)//矩阵快速幂函数,s1为矩阵,n为幂次
  50. {
  51. matrix mul=s1,ans;
    //将ans构造为单位矩阵
  52. ans.row=ans.column=s1.row;
  53. memset(ans.arrcy,,sizeof ans.arrcy);
  54. for(int i=;i<ans.row;i++)
  55. ans.arrcy[i][i]=;
  56. while(n)
  57. {
  58. if(n&) ans=ans*mul;
  59. mul=mul*mul;
  60. n/=;
  61. }
  62. return ans;
  63. }
  64. int main()
  65. {
  66. ios::sync_with_stdio(false);
  67. cin.tie();
  68. int n,a,b;
  69. cin>>n>>a>>b;
  70. matrix mul;
  71. mul.row=mul.column=;
  72. mul.arrcy[][]=a;
  73. mul.arrcy[][]=b;
  74. mul.arrcy[][]=;
  75. mul.arrcy[][]=;
  76. matrix r;
  77. r.row=;
  78. r.column=;
  79. r.arrcy[][]=r.arrcy[][]=;
  80. rep(i,,n)
  81. {
  82. int x;
  83. cin>>x;
  84. if(!x)//当x=1时,x-1<0无法使用快速幂,答案为0,特判即可
  85. {
  86. cout<<<<endl;
  87. continue;
  88. }
  89. matrix mm=quick_pow(mul,x-);
  90. mm=mm*r;
  91. cout<<mm.arrcy[][]<<endl;
  92. }
  93. return ;
  94. }

FZU2018级算法第一次作业 1.1fibonacci (矩阵快速幂)的更多相关文章

  1. bzoj 2326: [HNOI2011]数学作业【dp+矩阵快速幂】

    矩阵乘法一般不满足交换律!!所以快速幂里需要注意乘的顺序!! 其实不难,设f[i]为i的答案,那么f[i]=(f[i-1]w[i]+i)%mod,w[i]是1e(i的位数),这个很容易写成矩阵的形式, ...

  2. 【BZOJ】2004: [Hnoi2010]Bus 公交线路 状压DP+矩阵快速幂

    [题意]n个点等距排列在长度为n-1的直线上,初始点1~k都有一辆公车,每辆公车都需要一些停靠点,每个点至多只能被一辆公车停靠,且每辆公车相邻两个停靠点的距离至多为p,所有公车最后会停在n-k+1~n ...

  3. 【BZOJ】2553: [BeiJing2011]禁忌 AC自动机+期望+矩阵快速幂

    [题意]给定n个禁忌字符串和字符集大小alphabet,保证所有字符在集合内.一个字符串的禁忌伤害定义为分割能匹配到最多的禁忌字符串数量(一个可以匹配多次),求由字符集构成的长度为Len的字符串的期望 ...

  4. 【BZOJ】4861: [Beijing2017]魔法咒语 AC自动机+DP+矩阵快速幂

    [题意]给定n个原串和m个禁忌串,要求用原串集合能拼出的不含禁忌串且长度为L的串的数量.(60%)n,m<=50,L<=100.(40%)原串长度为1或2,L<=10^18. [算法 ...

  5. 算法设计与分析 1.2 不一样的fibonacci数列 (矩阵快速幂思想)

    题目描述 Winder 最近在学习 fibonacci 数列的相关知识.我们都知道 fibonacci 数列的递推公式是F(n) = F(n - 1) + F(n - 2)(n >= 2 且 n ...

  6. 【BZOJ1009】GT考试(KMP算法,矩阵快速幂,动态规划)

    [BZOJ1009]GT考试(KMP算法,矩阵快速幂,动态规划) 题面 BZOJ 题解 看到这个题目 化简一下题意 长度为\(n\)的,由\(0-9\)组成的字符串中 不含串\(s\)的串的数量有几个 ...

  7. 整数快速乘法/快速幂+矩阵快速幂+Strassen算法

    快速幂算法可以说是ACM一类竞赛中必不可少,并且也是非常基础的一类算法,鉴于我一直学的比较零散,所以今天用这个帖子总结一下 快速乘法通常有两类应用:一.整数的运算,计算(a*b) mod c  二.矩 ...

  8. 51nod 算法马拉松18 B 非010串 矩阵快速幂

    非010串 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 如果一个01字符串满足不存在010这样的子串,那么称它为非010串. 求长度为n的非010串的个数.(对1e9+7取模) ...

  9. BZOJ 1009 :[HNOI2008]GT考试(KPM算法+dp+矩阵快速幂)

    这道到是不用看题解,不过太经典了,早就被剧透一脸了 这道题很像ac自动机上的dp(其实就是) 然后注意到n很大,节点很小,于是就可以用矩阵快速幂优化了 时间复杂度为o(m^3 *log n); 蒟蒻k ...

随机推荐

  1. Spark-源码分析03-SubmitTask

    1.Rdd rdd中 reduce.fold.aggregate.collect.count这些方法 都会调用 sparkContext.runJob ,这些方法称之为Action 触发提交Job d ...

  2. 2019-2020-1 20199302《Linux内核原理与分析》第九周作业

    一.进程调度的时机 硬中断和软中断 中断:程序执行过程中的强制性转移到操作系统内核相应的处理程序,起到切出指令流的作用. 中断处理程序:与进程无关的内核指令流. 进程切换:切换两个进程的内核堆栈. 硬 ...

  3. Lightning Web Components 组件生命周期(六)

    组件创建以及渲染流程 组件移除dom 处理流程 组件从dom 移除 组件中的disconnectedCallback() 方法被调用 子组件从dom 移除 每个子组件的disconnectedCall ...

  4. SP19997 MOON2 - Moon Safari (Hard) 【数论,多项式】

    题目描述:求 \[ \sum_{i=1}^ni^kr^i \] 对某个质数取模.\(T\)组数据. 数据范围:\(n,r\le 10^{18},\sum k\le 2.56\times 10^6\) ...

  5. PCA与ICA

    关于机器学习理论方面的研究,最好阅读英文原版的学术论文.PCA主要作用是数据降维,而ICA主要作用是盲信号分离.在讲述理论依据之前,先思考以下几个问题:真实的数据训练总是存在以下几个问题: ①特征冗余 ...

  6. C++通过迭代修改字符串本身(auto类型说明符)

    以字符串这种支持 for (declaration : expression) statement 这样for语句迭代的数据结构为例,我们看看auto关键字在类型推断中的作用. string s = ...

  7. vuejs cli3 env配置文件实践指南

    env文件 配置四个环境名字分别 VUE_APP_ENV=dev 只支持:VUE_APP_ 开头,比如设置其它变量 VUE_APP_NAME=stark package.json 配置 方式 &quo ...

  8. 用DLL方式封装MDI子窗体

    用DLL方式封装MDI子窗体是一种常用的软件研发技术,他的长处: 研发人员能够负责某一个模块的编写包括(界面+逻辑),能够互不干扰,模块研发完成后,主程式统一调用. 易于程式升级,当程式升级时,不用编 ...

  9. Research Guide for Neural Architecture Search

    Research Guide for Neural Architecture Search 2019-09-19 09:29:04 This blog is from: https://heartbe ...

  10. 将linux上的网站代码托管到gogs git服务器上进行实时同步(实战)

    一.说明 本说明只针对php,其他语言需要编译请用别的架构实现 二.实现效果 本地开发员门提交推送代码到git服务器,会立即同步更新网站服务器上代码 三.实战步骤小节 首次托管请先看   https: ...