题目链接http://acm.hdu.edu.cn/showproblem.php?pid=4549;

题目是中文的很容易理解吧。可一开始我把题目看错了,这毛病哈哈。 一开始我看错题时,就用了一个快速幂来解,不用说肯定wa,看题目的通过率也不高,我想会不会有啥坑啊。然而我就是那大坑,哈哈。

不说了,直接说题吧,先讨论k=1,2,3;时的解。这应该会解吧,不多说了;

从第四项开始f(4)=a^1+b^2;f(5)=a^2+b^3;f(6)=a^3+b^5......; 看出来了吧,a上的指数成斐波那契数列,b的也成,而且a的指数是b的前一项;

那么就打表求斐波那契数列呗,不敢,范围太大,又爆内存又超时的。

f(n)=a^k(n-4)+b^k(n-3);其中n>=4;k(0)=1;k(1)=2;

用矩阵来求斐波那契数列的相邻两项有[k[n-2],k[n-1]]*[0 1]

[1 1]

上式等于[k[n-1],k[n]];

那么要求[k[n-4],k[n-3]]=[1,2]*[0 1]^(n-3)

[1 1]

这样就可以用矩阵快速幂来求k[n-4],k[n-3]了;

但光这样还不够,在矩阵快速幂过程中还得取模,不然会溢出。

由费马小定理在p为素数的情况下对任意的整数x都有x^p==x(mod p)

;如果x不能被p整除有x^(p-1)=1(mod p);由于a,b<1e9;所以不能被1e9+7整除, 求出了k[n],则a^k[n]%p=a^(k[n]%(p-1))%p;

证明如下: k[n]=m*(p-1)+d;那么a^k[n]%p=a^[(m*(p-1))+d]%p=(a^[m*(p-1)]%p*a^(d)%p)%p;

由费马小定理可知a^(m*(p-1))%p=1; 而d=k[n]%(p-1);得证;

所以矩阵快速幂时要对1e+6取模就行了; 当k(n)求出来是再进行快速幂运算就可以了,复杂度为2*log2(n); 注意要开longlong不然会溢出。

下面看代码:

  1 #include<stdio.h>
2 #include<string.h>
3 #include<iostream>
4 #include<algorithm>
5 #include<stdlib.h>
6 #include<math.h>
7 const long long N=1e9+7;
8 const long long M=1e9+6;
9 typedef long long ll;
10 void kk(ll y);
11 ll pp(ll x,ll y);
12 ll b[2][2];
13 ll a[2][2];
14 using namespace std;
15 int main(void)
16 {
17 ll i,j,k,p,q,n,m;
18
19 while(scanf("%lld%lld%lld",&p,&q,&k)!=EOF)
20 {
21 if(k==0)
22 {
23 printf("%lld\n",p%N);
24
25 }
26 else if(k==1)
27 {
28 printf("%lld\n",q%N);
29
30 }
31 else if(k==2)
32 {
33 printf("%lld\n",(p%N*q%N)%N);
34 }
35 else
36 {
37 k=k-3;
38 kk(k);
39 ll p1=(b[0][0]%M+2*b[1][0]%M)%M;//求的k(n-4)
40 ll p2=(b[0][1]%M+2*b[1][1]%M)%M;//k[n-3]
41 ll x1=pp(p,p1);//a^k(n-4);
42 ll x2=pp(q,p2);//b^k(n-3);
43 ll dd=(x1*x2)%N;//d=(a^k(n-4)*b^k(n-3))%N;
44 printf("%lld\n",dd);
45
46 }
47
48 }
49
50 return 0;
51
52 }
53
54 ll pp(ll x,ll y)//快速幂
55 {
56 ll p=x;
57 ll q=1;
58
59 while(y)
60 {
61 if(y&1)
62 {
63 q=(q%N*p%N)%N;
64 }
65 p=(p%N*p%N)%N;
66
67 y=y/2;
68 }
69 return q;
70
71 }
72
73
74 void kk(ll y)//矩阵快速幂 形式和快速幂基本一样。
75 {
76 ll i,j,k;
77 ll x1,x2,x3,x4;
78 a[0][0]=0;//a为变换矩阵;
79 a[0][1]=1;
80 a[1][0]=1;
81 a[1][1]=1;
82 b[0][0]=1;//b为单位阵;
83 b[0][1]=0;
84 b[1][0]=0;
85 b[1][1]=1;
86
87 while(y)
88 {
89 if(y&1)
90 {
91 x1=((b[0][0]*a[0][0])%M+(b[0][1]*a[1][0])%M)%M;
92 x2=((b[0][0]*a[0][1])%M+(b[0][1]*a[1][1])%M)%M;
93 x3=((b[1][0]*a[0][0])%M+(b[1][1]*a[1][0])%M)%M;
94 x4=((b[1][0]*a[0][1])%M+(b[1][1]*a[1][1])%M)%M;
95 b[0][0]= x1;
96 b[0][1]=x2;
97 b[1][0]=x3;
98 b[1][1]=x4;
99 }
100 x1=((a[0][0]*a[0][0])%M+(a[0][1]*a[1][0])%M)%M;
101 x2=((a[0][0]*a[0][1])%M+(a[0][1]*a[1][1])%M)%M;
102 x3=((a[1][0]*a[0][0])%M+(a[1][1]*a[1][0])%M)%M;
103 x4=((a[1][0]*a[0][1])%M+(a[1][1]*a[1][1])%M)%M;
104 a[0][0]=x1;
105 a[0][1]=x2;
106 a[1][0]=x3;
107 a[1][1]=x4;
108 y/=2;
109
110 }
111
112
113
114
115 }

hdu 4549 M斐波那契数列(快速幂 矩阵快速幂 费马小定理)的更多相关文章

  1. HDU 4549 M斐波那契数列(矩阵快速幂+费马小定理)

    M斐波那契数列 Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 65535/32768K (Java/Other) Total Submi ...

  2. [HDU 4549] M斐波那契数列

    M斐波那契数列 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Sub ...

  3. HDU 4549 M斐波那契数列(矩阵快速幂)

    题目链接:M斐波那契数列 题意:$F[0]=a,F[1]=b,F[n]=F[n-1]*F[n-2]$.给定$a,b,n$,求$F[n]$. 题解:暴力打表后发现$ F[n]=a^{fib(n-1)} ...

  4. hdu 4549 M斐波那契数列 矩阵快速幂+欧拉定理

    M斐波那契数列 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Problem ...

  5. POJ3070 斐波那契数列递推 矩阵快速幂模板题

    题目分析: 对于给出的n,求出斐波那契数列第n项的最后4为数,当n很大的时候,普通的递推会超时,这里介绍用矩阵快速幂解决当递推次数很大时的结果,这里矩阵已经给出,直接计算即可 #include< ...

  6. hdu 4549 M斐波那契数列(矩阵高速幂,高速幂降幂)

    http://acm.hdu.edu.cn/showproblem.php?pid=4549 f[0] = a^1*b^0%p,f[1] = a^0*b^1%p,f[2] = a^1*b^1%p... ...

  7. HDU 4549 M斐波那契数列(矩阵幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4549 题意:F[0]=a,F[1]=b,F[n]=F[n-1]*F[n-2]. 思路:手算一下可以发现 ...

  8. Tribonacci UVA - 12470 (简单的斐波拉契数列)(矩阵快速幂)

    题意:a1=0;a2=1;a3=2; a(n)=a(n-1)+a(n-2)+a(n-3);  求a(n) 思路:矩阵快速幂 #include<cstdio> #include<cst ...

  9. HDU 1316 (斐波那契数列,大数相加,大数比较大小)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1316 Recall the definition of the Fibonacci numbers: ...

随机推荐

  1. accommodate, accompany

    accommodate 词源: to make fit, suitable; 近/反义词: adapt, adjust, lodge; disoblige, incommode, misfit Lod ...

  2. HTML5 基础内容(元素/属性/格式化)

    HTML基础 1.HTML元素 1.1 元素指的是开始标签到结束标签的所有代码. 1.2 元素的内容是开始标签与结束标签之间的内容. 1.3大多数HTML元素可用有属性. 1.4标签可以拥有属性为元素 ...

  3. CVTE第二次笔试

    选择瞎答得,直接编程题目 1. 使用递归将字符串中的数字去并按顺序打印 输入例  adfsafsfs123123eogie09789 输出例 123123 09789 #include<iost ...

  4. 事务(@Transactional注解)的用法和实例

    参数 @Transactional可以配制那些参数及以其所代表的意义: 参数 意义 isolation 事务隔离级别 propagation 事务传播机制 readOnly 事务读写性 noRollb ...

  5. github单独下载某一个文件夹

    可以借助svn工具进行下载,实现只下载repo下的指定文件夹内容 背景 需要下载这个文件夹下所有内容https://github.com/rabbitmq/rabbitmq-tutorials/tre ...

  6. Java Maven项目搭建

    创建空项目 New Project --> Empty Project --> ... 配置JDK Project Settings --> Project 选择JDK Module ...

  7. Spring Boot的异步任务、定时任务和邮件任务

    一.异步任务 1.启动类添加注解@EnableAsync,开启异步任务注解功能: 2.需要异步执行的方法上添加@Async注解. 二.定时任务 1.启动类添加注解@EnableScheduling,开 ...

  8. 面渣逆袭:Java集合连环三十问

    大家好,我是老三.上期发布了一篇:面渣逆袭:HashMap追魂二十三问,反响很好! 围观群众纷纷表示 不写,是不可能不写的,只有卷才能维持了生活这样子. 当然,我写的这一系列,不是背诵版,是理解版,很 ...

  9. Nginx模块之ngx_http_gzip_module

    Module ngx_http_gzip_module 该ngx_http_gzip_module模块是一个使用"gzip"方法压缩响应的过滤器.这通常有助于将传输数据的大小减少一 ...

  10. 为什么重写equals()就要重写hashcode()

    阿里巴巴开发规范 只要重写 equals,就必须重写 hashCode 因为 Set 存储的是不重复的对象,依据 hashCode 和 equals 进行判断,所以 Set 存储的对象必须重写这两个方 ...