3969 [Mz]平方和

 时间限制: 1 s
 空间限制: 64000 KB
 题目等级 : 大师 Master
 查看运行结果
 
 
题目描述 Description

斐波那契数列:f[0]=0,f[1]=1,f[i]=f[i-1]+f[i-2](i>1)

求f[1]*f[1]+f[2]*f[2]+...+f[n]*f[n]的值

输入描述 Input Description

仅一行,一个正整数n

输出描述 Output Description

仅一行一个数,即所求的值,由于结果可能很大,需对1,000,000,007取模

样例输入 Sample Input

3

样例输出 Sample Output

6

数据范围及提示 Data Size & Hint

对于100‰的数据,n<=1,000,000=10^6

然而:

对于200‰的数据,n<=9,000,000,000,000,000,000=9*10^18

对于500‰的数据,n<=10^500

对于1000‰的数据,n<=10^50000

分类标签 Tags 点此展开

引理1:

  平方求和

  
 
关于模数,Seavot__提供。
  1. #include<cstdio>
  2. using namespace std;
  3. typedef long long ll;ll n;
  4. const ll mod=;
  5. char s[];
  6. struct matrix{ll s[][];}A,F;
  7. ll mul(ll a,ll b){
  8. ll res=;
  9. for(;b;b>>=,a=(a+a)%mod) if(b&) res=(res+a)%mod;
  10. return res;
  11. }
  12. matrix operator *(const matrix &a,const matrix &b){
  13. matrix c;
  14. for(int i=;i<;i++){
  15. for(int j=;j<;j++){
  16. c.s[i][j]=;
  17. for(int k=;k<;k++){
  18. c.s[i][j]+=mul(a.s[i][k],b.s[k][j]);
  19. c.s[i][j]%=mod;
  20. }
  21. }
  22. }
  23. return c;
  24. }
  25. matrix fpow(matrix a,ll p){
  26. matrix ans;
  27. for(int i=;i<;i++) for(int j=;j<;j++) ans.s[i][j]=(i==j);
  28. for(;p;p>>=,a=a*a) if(p&) ans=ans*a;
  29. return ans;
  30. }
  31. void deal(){
  32. for(int i=;s[i];i++){
  33. n=(n*+s[i]-'')%(mod+);
  34. }
  35. }
  36. int main(){
  37. scanf("%s",s);deal();
  38. A.s[][]=A.s[][]=A.s[][]=;A.s[][]=;
  39. F.s[][]=;F.s[][]=F.s[][]=F.s[][]=;
  40. F=fpow(A,n)*F;
  41. ll ans=F.s[][]*F.s[][]%mod;
  42. printf("%lld\n",ans);
  43. return ;
  44. }
 
暂无标签
 

3969 [Mz]平方和【斐波那契平方和】的更多相关文章

  1. Cogs 1708. 斐波那契平方和(矩阵乘法)

    斐波那契平方和 ★★☆ 输入文件:fibsqr.in 输出文件:fibsqr.out 简单对比 时间限制:0.5 s 内存限制:128 MB [题目描述] ,对 1000000007 取模.F0=0, ...

  2. 费马平方和定理&&斐波那契恒等式&&欧拉四平方和恒等式&&拉格朗日四平方和定理

    费马平方和定理 费马平方和定理的表述是:奇素数能表示为两个平方数之和的充分必要条件是该素数被4除余1. 1. 如果两个整数都能表示为两个平方数之和的形式,则他们的积也能表示为两个平方数之和的形式. $ ...

  3. C#求斐波那契数列第30项的值(递归和非递归)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  4. python迭代器实现斐波拉契求值

    斐波那契数列(Fibonacci sequence),又称黄金分割数列,也称为"兔子数列":F(0)=0,F(1)=1,F(n)=F(n-1)+F(n-2)(n≥2,n∈N*).例 ...

  5. Ural 1225. Flags 斐波那契DP

    1225. Flags Time limit: 1.0 secondMemory limit: 64 MB On the Day of the Flag of Russia a shop-owner ...

  6. 斐波拉契数列加强版——时间复杂度O(1),空间复杂度O(1)

    对于斐波拉契经典问题,我们都非常熟悉,通过递推公式F(n) = F(n - ) + F(n - ),我们可以在线性时间内求出第n项F(n),现在考虑斐波拉契的加强版,我们要求的项数n的范围为int范围 ...

  7. js中的斐波那契数列法

    //斐波那契数列:1,2,3,5,8,13…… //从第3个起的第n个等于前两个之和 //解法1: var n1 = 1,n2 = 2; for(var i=3;i<101;i++){ var ...

  8. 剑指Offer面试题:8.斐波那契数列

    一.题目:斐波那契数列 题目:写一个函数,输入n,求斐波那契(Fibonacci)数列的第n项.斐波那契数列的定义如下: 二.效率很低的解法 很多C/C++/C#/Java语言教科书在讲述递归函数的时 ...

  9. 算法: 斐波那契数列C/C++实现

    斐波那契数列: 1,1,2,3,5,8,13,21,34,....     //求斐波那契数列第n项的值 //1,1,2,3,5,8,13,21,34... //1.递归: //缺点:当n过大时,递归 ...

随机推荐

  1. mongodb安装的两条命令

    1. 安装 下载并安装,注意安装方式为custom,路径自定义(d:\chengxu\mongodb),安装成功后在mongodb文件夹下新建data文件夹(内新建db文件夹)和logs文件夹(内新建 ...

  2. Cassandra VS HBase

    HBase(dfs三副本,syncwal) Cassandra(N=3,W=2,R=2, batch commitlog) CAP CP CA 数据存储模型 LSM LSM 数据写入网络开销 Rpc  ...

  3. spring jdbc框架

    spring+jdbc 1.jdbc编程的特点: 模板编程 固定代码+动态的参数 spring产生dataSource JdbcTemplate{//模板编程 private DataSource d ...

  4. Eclipse - JAR包制作

    Eclipse - JAR包制作细节   1.Jar包分为两种,一种是不可运行的,一种是可运行的Jar包,他们的主要区别如下:     > 不可直接运行的Jar包主要是用于给别的程序提供调用   ...

  5. cmd隐藏指定文件

    隐藏文件: 或者带路径执行: 显示文件:

  6. C# LDAP

    Lightweight Directory Access Protocol OpenLDAP

  7. 图片onerror事件,为图片加载指定默认图片

    为图片指定加载失败时显示默认图片,js输出的img对象,onerror是事件,不是属性,所以这样写是不起作用的: var img = $(document.createElement("IM ...

  8. debian下运行netstat失败

    如果提示:bash: netstat: command not found 说明没有安装netstat工具,而该工具在 net-tools 工具包内. apt-get install net-tool ...

  9. Unity 扩展编辑器

    扩展Inspector界面 继承自Editor,添加CustomEditorAttribute,传入定制的类型 定制显示的类型要求: 类型中所有的public 字段都会自动暴露给Inspector编辑 ...

  10. Oracle配置客户端

    一.引言 当我们需要连接远程的Oracle数据库服务器时,就需要在自己的机器上安装Oracle客户端了. 二.安装步骤与配置 参考:http://blog.csdn.net/luiseradl/art ...