hdu1588 Gauss Fibonacci (矩阵快速幂)

P.S. 感谢大神,借鉴于此:http://blog.csdn.net/shiyuankongbu/article/details/8458459  讲的真心很明白,,,       


题目大意:给定k, n, b, M , 求斐波那契数列第b项到第 k*i+b 项( 0<=i<n)的和sum(n) % M的值。


解题思路:对于F(b) + F(k+b) + F(2*k+b) + … + F( (n-1) * k+b )   我们用矩阵快速幂处理 可得:T = B^b + B^(k+b) + B^(2*k+b) +…+ B^((n-1)*k +b)  = B^b * [ E + B^k + B^(2*k) +…+B^((n-1)*k) ] (其中E为单位阵);然后中括号里面用二分解决,,,很麻烦,,,


代码如下:

#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cmath>
#include <algorithm>
using namespace std;
typedef struct
{
     long long m[2][2];
}Matrix;

Matrix B, E;
long long n, k, b, M;
void init()
{
     B.m[0][0] = B.m[0][1] = B.m[1][0] = 1;
     B.m[1][1] = 0;
     E.m[0][0] = E.m[1][1] = 1;
     E.m[0][1] = E.m[1][0] = 0;
}

Matrix multi(Matrix a, Matrix b)
{
     Matrix c;
     for(int i = 0; i < 2; i ++)
     {
             for(int j = 0; j < 2; j ++)
             {
                     c.m[i][j] = 0;
                     for(int k = 0; k < 2; k ++)
                     {
                             c.m[i][j] = c.m[i][j] + a.m[i][k] * b.m[k][j] % M;
                     }
                     c.m[i][j] = c.m[i][j] % M;
             }
     }
     return c;
}

Matrix Power(Matrix A, int k)
{
     Matrix ans = E;
     while(k)
     {
            if(k & 1) ans = multi(ans, A);
            k = k / 2;
            A = multi(A, A);
     }
     return ans;
}

Matrix Add(Matrix a, Matrix b)
{
     Matrix c;
     for(int i = 0; i < 2; i ++)
     {
             for(int j = 0; j < 2; j ++)
             {
                     c.m[i][j] = (a.m[i][j] + b.m[i][j])% M;
             }
     }
     return c;
}

Matrix Sum(Matrix a, long long n)
{
     Matrix ans;
     if(n == 0)
     {
          ans.m[0][0] = ans.m[0][1] = ans.m[1][0] = ans.m[1][1] = 0;
          return ans;
     }
     if(n == 1)
          return a;
     else
     {
             //  cnt=A^k
            // sum(n) = A^k+A^2k+...A^(n-1)k
            //        = cnt+cnt^2+cnt^3+...cnt^(n-1)
            //   t=sum(n/2)
            // sum(n) = sum(n/2) + cnt^(n/2+1)+cnt^(n/2+2)+...cnt^(n-1)
            // sum(n) =  t +  cnt^(n/2+1)+cnt^(n/2+2)+...cnt^(n-1)
            // sum(n) =  t +  t * cnt^(n/2)
            //  递归到最后的时候,n为奇数时直接算,相当于 n=39时
            //  sum(39) = cnt^1+cnt^2+...+cnt^39  t=19
            //  sum(39) = sum(19)+sum(19)*cnt^19+ cnt^39 (最后一项是因为n为奇数所余留的一项)
            Matrix res, t;
            t = Sum(a, n/2);
            res = Add(t, multi(Power(a, n/2), t));
            if(n & 1)
                  res = Add(res, Power(a, n));
            return res;
     }
}
int  main()
{
     while(~scanf("%lld %lld %lld %lld", &k, &b, &n, &M) && k + b + n + M)
     {
           init();
           Matrix M1 = Power(B, k);
           Matrix M2 = Power(B, b);
           Matrix res = multi(M2, Add(E, Sum(M1, n-1)));
           printf("%lld\n", res.m[0][1]);
     }
     return 0;
}

                  

   

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值