题目链接:http://poj.org/problem?

id=3070

题目大意:给定n和10000,求第n个Fibonacci数mod 10000 的值,n不超过2^31。

结果保留四位数字。

非常easy的题,和之前做过的相比简单非常多了。

构造最简单的斐波那契数列矩阵。

  1. #include<iostream>
  2. #include<cstring>
  3. #include<stdio.h>
  4. using namespace std;
  5. const int MAX = 2;
  6.  
  7. struct Matrix
  8. {
  9. int v[MAX][MAX];
  10. };
  11.  
  12. int n=2,M=10000;
  13.  
  14. Matrix mtAdd(Matrix A, Matrix B) // 求矩阵 A + B
  15. {
  16. int i, j;
  17. Matrix C;
  18. for(i = 0; i < n; i ++)
  19. for(j = 0; j < n; j ++)
  20. C.v[i][j]=(A.v[i][j]+B.v[i][j])% M;
  21. return C;
  22. }
  23.  
  24. Matrix mtMul(Matrix A, Matrix B) // 求矩阵 A * B
  25. {
  26. int i, j, k;
  27. Matrix C;
  28. for(i = 0; i < n; i ++)
  29. for(j = 0; j < n; j ++)
  30. {
  31. C.v[i][j] = 0;
  32. for(k = 0; k < n; k ++)
  33. C.v[i][j] = (A.v[i][k] * B.v[k][j] + C.v[i][j]) % M;
  34. }
  35. return C;
  36. }
  37.  
  38. Matrix mtPow(Matrix origin,int k) //矩阵高速幂
  39. {
  40. int i;
  41. Matrix res;
  42. memset(res.v,0,sizeof(res.v));
  43. for(i=1;i<=n;i++)
  44. res.v[i][i]=1;
  45. while(k)
  46. {
  47. if(k&1)
  48. res=mtMul(res,origin);
  49. origin=mtMul(origin,origin);
  50. k>>=1;
  51. }
  52. return res;
  53. }
  54.  
  55. void out(Matrix A)
  56. {
  57. for(int i=0;i<n;i++)
  58. {
  59. for(int j=0;j<n;j++)
  60. cout<<A.v[i][j]<<" ";
  61. cout<<endl;
  62. }
  63. cout<<endl;
  64. }
  65.  
  66. Matrix mtCal(Matrix A, int k) // 求S (k) = A + A2 + A3 + … + Ak
  67. {
  68. if(k == 1) return A;
  69. Matrix B = mtPow(A, (k+1) / 2);
  70. Matrix C = mtCal(A, k / 2);
  71. if(k % 2 == 0)
  72. return mtMul(mtAdd(mtPow(A, 0), B), C); // 如S(6) = (1 + A^3) * S(3)。
  73. else
  74. return mtAdd(A, mtMul(mtAdd(A, B), C)); // 如S(7) = A + (A + A^4) * S(3)
  75. }
  76.  
  77. int main ()
  78. {
  79. int num;
  80. while (~scanf("%d",&num))
  81. {
  82. if(num==-1) break;
  83. Matrix A;
  84. A.v[0][0]=1;
  85. A.v[0][1]=1;
  86. A.v[1][0]=1;
  87. A.v[1][1]=0;
  88. Matrix ans=mtPow(A,num);
  89. //out(ans);
  90. cout<<ans.v[1][0]<<endl;
  91. }
  92. }

矩阵十题【六】 poj3070 Fibonacci的更多相关文章

  1. [矩阵十题第七题]vijos 1067 Warcraft III 守望者的烦恼 -矩阵快速幂

    背景 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她传送到后面的监狱内查看,她比较懒,一般不查看 ...

  2. hdu 2157 How many ways?? ——矩阵十题第八题

    Problem Description 春天到了, HDU校园里开满了花, 姹紫嫣红, 非常美丽. 葱头是个爱花的人, 看着校花校草竞相开放, 漫步校园, 心情也变得舒畅. 为了多看看这迷人的校园, ...

  3. 矩阵十题【五】 VOJ1049 HDU 2371 Decode the Strings

    题目链接:https://vijos.org/p/1049 题目大意:顺次给出m个置换,重复使用这m个置换对初始序列进行操作.问k次置换后的序列.m<=10, k<2^31. 首先将这m个 ...

  4. Java实习生常规技术面试题每日十题Java基础(六)

    目录 1.在Java语言,怎么理解goto. 2.请描述一下Java 5有哪些新特性? 3.Java 6新特性有哪些. 4.Java 7 新特性有哪些. 5.Java 8 新特性有哪些. 6.描述Ja ...

  5. C语言考试解答十题

    学院比较奇葩,大一下期让学的VB,这学期就要学C++了,然后在开学的前三个周没有课,就由老师讲三个周的C语言,每天9:30~11:30听课,除去放假和双休日,实际听课时间一共是12天*2小时,下午是1 ...

  6. Java实习生常规技术面试题每日十题Java基础(八)

    目录 1.解释内存中的栈(stack).堆(heap)和静态区(static area)的用法. 2.怎样将GB2312编码的字符串转换为ISO-8859-1编码的字符串? 3.运行时异常与受检异常有 ...

  7. Java实习生常规技术面试题每日十题Java基础(七)

    目录 1. Java设计模式有哪些? 2.GC是什么?为什么要有GC? 3. Java中是如何支持正则表达式. 4.比较一下Java和JavaSciprt. 5.Math.round(11.5) 等于 ...

  8. Java实习生常规技术面试题每日十题Java基础(五)

    目录 1.启动一个线程是用run()还是start()? . 2.线程的基本状态以及状态之间的关系. 3.Set和List的区别,List和Map的区别? 4.同步方法.同步代码块区别? 5.描述Ja ...

  9. Java实习生常规技术面试题每日十题Java基础(四)

    目录 1.String 和StringBuffer的区别. 2.数组有没有length()这个方法? String有没有length()这个方法? 3.final, finally, finalize ...

随机推荐

  1. django+nginx+mod_wsgi+apache网站部署

    软件安装 0.如果对selunix不熟就先把它停掉 vi /etc/selinux/config 改动selinux=diabled 然后重启计算机 1.编译安装python mod_wsgi的安装需 ...

  2. 属性动画详解一(Property Animation)

    效果图: Android动画有3类: 1.View Animation (Tween Animation) 2.Drawable Animation (Frame Animation) 2.Prope ...

  3. Java使用apache的开源数据处理框架commons-dbutils完成查询结果集的各种处理输出(8种方式)

    package demo; /* * QueryRunner数据查询操作: * 调用QueryRunner类方法query(Connection con,String sql,ResultSetHan ...

  4. hdu 4497(排列组合+LCM和GCD)

    GCD and LCM Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total ...

  5. 一种极简的异步超时处理机制设计与实现(C#版)

    1.引言 当执行某些动作之后,会期待反馈.最终要么是得到了结果,要么就是超时了.当超时发生时,可能是期望得到通知,或是希望能自动重试,等等.于是设计了一种通用的异步超时的处理机制,以期通过简洁易理解的 ...

  6. 某考试 T1 str

    一开始死磕sam,发现根本没法做...... 后来想了想,反正匹配子串的大部分不是sam就是 二分+hash啊,,,于是就想了想二分+hash,发现好像可以做啊! 就是假设我们要让 s1[1] 映射到 ...

  7. Java泛型构造函数

    1.概述 我们之前讨论过Java Generics的基础知识.在本文中,我们将了解Java中的通用构造函数. 泛型构造函数是至少需要有一个泛型类型参数的构造函数.我们将看到泛型构造函数并不都是在泛型类 ...

  8. Delphi Integer 转成单字节

    整形不能超过256 b:=Byte(StrToInt(n)); var   s: string;   b: Byte; begin   s := Edit1.Text;   b := Byte(Str ...

  9. ubuntu下virtualbox 共享文件夹 & 访问USB设备

    在Ubuntu 12.04 上为Virtualbox 启用USB 设备支持 Ubuntu安装虚拟机,实现文件和USB的共享 Ubuntu下virtualbox 虚拟xp 访问USB设备

  10. 手动编译高速扫描器MasScan

    常见的端口扫描器有NMAP,ZMAP,superScan等,我们使用后各有千秋,ZMAP号称44分钟扫全球ip,那么有没有比ZMAP更快的端口扫描器呢,今天我们来研究下masscan,这款扫描器号称3 ...