1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstring>
  4. #include<set>
  5. #include<queue>
  6. #include<vector>
  7. #include<map>
  8. using namespace std;
  9. #define ll long long
  10. int m[][],a,b,n,t[][];
  11. int temp[][];
  12. void power(int x)
  13. {
  14. if(x==)
  15. {
  16. m[][]=m[][]=;
  17. m[][]=m[][]=;
  18. return ;
  19. }
  20. if(x==)
  21. {
  22. m[][]=a%;
  23. m[][]=b%;
  24. m[][]=;
  25. m[][]=;
  26. return ;
  27. }
  28. power(x>>);
  29. for(int i=;i<=;i++)
  30. {
  31. for(int j=;j<=;j++)
  32. {
  33. temp[i][j]=;
  34. for(int k=;k<=;k++)
  35. {
  36. temp[i][j]=(temp[i][j]+(m[i][k]*m[k][j])%)%;
  37. }
  38. }
  39. }
  40. if(x&)
  41. {
  42. for(int i=;i<=;i++)
  43. {
  44. for(int j=;j<=;j++)
  45. {
  46. m[i][j]=;
  47. for(int k=;k<=;k++)
  48. {
  49. m[i][j]=(m[i][j]+(temp[i][k]*t[k][j])%)%;
  50. }
  51. }
  52. }
  53. }
  54. else
  55. {
  56. for(int i=;i<=;i++)
  57. {
  58. for(int j=;j<=;j++)
  59. {
  60. m[i][j]=temp[i][j];
  61. }
  62. }
  63. }
  64.  
  65. for(int i=;i<=;i++)
  66. {
  67. for(int j=;j<=;j++)
  68. {
  69. m[i][j]=m[i][j]%;
  70. }
  71. }
  72. return ;
  73. }
  74.  
  75. int main()
  76. {
  77.  
  78. while(scanf("%d%d%d",&a,&b,&n),a||b||n)
  79. {
  80.  
  81. t[][]=a%;
  82. t[][]=b%;
  83. t[][]=;
  84. t[][]=;
  85. if(n==||n==)
  86. {
  87. printf("1\n");
  88. continue;
  89. }
  90. else
  91. {
  92. power(n-);
  93. printf("%d\n",(m[][]+m[][])%);
  94. }
  95. }
  96. return ;
  97. }

鸣谢https://blog.csdn.net/cambridgeacm/article/details/7703809

hdu1005 矩阵快速幂的更多相关文章

  1. 矩阵快速幂(入门) 学习笔记hdu1005, hdu1575, hdu1757

    矩阵快速幂是基于普通的快速幂的一种扩展,如果不知道的快速幂的请参见http://www.cnblogs.com/Howe-Young/p/4097277.html.二进制这个东西太神奇了,好多优秀的算 ...

  2. HDU1005 找规律 or 循环点 or 矩阵快速幂

    http://acm.hdu.edu.cn/showproblem.php?pid=1005 1.一开始就注意到了n的数据范围 <=100 000 000,但是还是用普通的循环做的,自然TLE了 ...

  3. 矩阵快速幂 HDU 4565 So Easy!(简单?才怪!)

    题目链接 题意: 思路: 直接拿别人的图,自己写太麻烦了~ 然后就可以用矩阵快速幂套模板求递推式啦~ 另外: 这题想不到或者不会矩阵快速幂,根本没法做,还是2013年长沙邀请赛水题,也是2008年Go ...

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

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

  5. 51nod 1113 矩阵快速幂

    题目链接:51nod 1113 矩阵快速幂 模板题,学习下. #include<cstdio> #include<cmath> #include<cstring> ...

  6. 【66测试20161115】【树】【DP_LIS】【SPFA】【同余最短路】【递推】【矩阵快速幂】

    还有3天,今天考试又崩了.状态还没有调整过来... 第一题:小L的二叉树 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣.所以,小L当时卡在了二叉树. ...

  7. HDU5950(矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5950 题意:f(n) = f(n-1) + 2*f(n-2) + n^4,f(1) = a , f(2 ...

  8. 51nod 1126 矩阵快速幂 水

    有一个序列是这样定义的:f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7. 给出A,B和N,求f(n)的值. Input 输 ...

  9. hdu2604(递推,矩阵快速幂)

    题目链接:hdu2604 这题重要的递推公式,找到公式就很easy了(这道题和hdu1757(题解)类似,只是这道题需要自己推公式) 可以直接找规律,推出递推公式,也有另一种找递推公式的方法:(PS: ...

随机推荐

  1. 【Go语言系列】2.3、Go语言基本程序结构:变量及常量

    1.什么变量 变量来源于数学,从根本上说,变量相当于是对一块数据存储空间的命名,程序可以通过定义一个变量来申请一块数据存储空间,之后可以通过引用变量名来使用这块存储空间. 1.1变量声明 Go 语言变 ...

  2. const与指针、引用

    const与指针类型 定义一个指针*p: const int* p = NULL; int const* p = NULL; int* const p = NULL; 上面两行定义完全等价,第三行则不 ...

  3. 网易MuMu模拟器不显示Menu(菜单)键的解决办法

    解决方法一: 前提:需要一个键盘 步骤: 1.直接按下键盘上的Menu键. 解决方法二: 前提:需要Root之后的文件浏览器 步骤: 1.在文件管理器中打开 /System 文件夹: 2.复制 bui ...

  4. 使用JDBC分别利用Statement和PreparedStatement来对MySQL数据库进行简单的增删改查以及SQL注入的原理

    一.MySQL数据库的下载及安装 https://www.mysql.com/ 点击DOWNLOADS,拉到页面底部,找到MySQL Community(GPL)Downloads,点击 选择下图中的 ...

  5. 《自拍教程22》wget_文件下载工具

    wget用途介绍 日常测试过程中,我们可以用wget命令,来下载一些资源文件. wget是一个很好文件下载命令, Linux操作系统下,自带wget命令. Windows操作系统下,需要自己去下载并配 ...

  6. MongoDB高可用架构集群管理(一)

    MongoDB数据库核心的两个特点:第一个特点是副本集的自动切换,保证数据的高可靠.服务的高可用:第二个特点是自动分片.服务的横向扩展能力. (一)副本集架构 MongoDB的副本集是一组保持相同数据 ...

  7. [Python]爬取 游民星空网站 每周精选壁纸(1080高清壁纸) 网络爬虫

    一.检查 首先进入该网站的https://www.gamersky.com/robots.txt页面 给出提示: 弹出错误页面 注: 网络爬虫:自动或人工识别robots.txt,再进行内容爬取 约束 ...

  8. 41.Python中加载静态文件

    在一个网页中,不仅仅只有一个html骨架,还需要css样式文件,js执行文件以及一些图片等.因此在DTL中加载静态文件时一个必须要解决的问题.在DTL中,使用static标签来加载静态文件.要使用st ...

  9. css3神奇的圆角边框、阴影框及其图片边框

    css3圆角,建议IE10以上 如果border-radius 单位是百分比,则参考为自身宽高,因此当宽高不一致时,圆角为不规则形状 如果border-radius 为50%,则为椭圆:当宽高一致时, ...

  10. Win10查看屏保的所在位置

    路径 C:\Users\Hlzy\AppData\Local\Packages\Microsoft.Windows.ContentDeliveryManager_cw5n1h2txyewy\Local ...