题意:

给你一个n*n的矩阵 让你求S:

思路:

只知道矩阵快速幂 然后nlogn递推是会TLE的。

所以呢 要把那个n换成log

那这个怎么搞呢

二分!

当k为偶数时:

当k为奇数时:

就按照这么搞就能搞出来了

(我是看的题解才A的,,, 中间乱搞的时候犯了一些脑残的错误)

  1. // by SiriusRen
  2. #include <cstdio>
  3. #include <cstring>
  4. using namespace std;
  5. int n,mod,k;
  6. struct matrix{int a[33][33];void init(){memset(a,0,sizeof(a));}}first;
  7. matrix mul(matrix a,matrix b){
  8. matrix temp;temp.init();
  9. for(int i=1;i<=n;i++)
  10. for(int j=1;j<=n;j++)
  11. for(int k=1;k<=n;k++)
  12. temp.a[i][j]=(temp.a[i][j]+a.a[i][k]*b.a[k][j])%mod;
  13. return temp;
  14. }
  15. matrix add(matrix a,matrix b){
  16. matrix temp;temp.init();
  17. for(int i=1;i<=n;i++)
  18. for(int j=1;j<=n;j++)
  19. for(int k=1;k<=n;k++)
  20. temp.a[i][j]=(a.a[i][j]+b.a[i][j])%mod;
  21. return temp;
  22. }
  23. matrix pow(matrix a,int x){
  24. matrix temp;
  25. x--;
  26. for(int i=1;i<=n;i++)
  27. for(int j=1;j<=n;j++)
  28. temp.a[i][j]=a.a[i][j];
  29. while(x){
  30. if(x&1)temp=mul(temp,a);
  31. a=mul(a,a),x>>=1;
  32. }
  33. return temp;
  34. }
  35. matrix recursive(int x){
  36. if(x==1)return first;
  37. matrix temp=recursive(x/2);
  38. if(x&1){
  39. matrix jy=pow(first,x/2+1);
  40. temp=add(temp,mul(temp,jy));
  41. return add(jy,temp);
  42. }
  43. else{
  44. matrix jy=pow(first,x/2);
  45. return add(mul(jy,temp),temp);
  46. }
  47. }
  48. int main(){
  49. scanf("%d%d%d",&n,&k,&mod);
  50. for(int i=1;i<=n;i++)
  51. for(int j=1;j<=n;j++){
  52. scanf("%d",&first.a[i][j]);
  53. first.a[i][j]=first.a[i][j]%mod;
  54. }
  55. matrix jy=recursive(k);
  56. for(int i=1;i<=n;i++){
  57. for(int j=1;j<n;j++)
  58. printf("%d ",jy.a[i][j]);
  59. printf("%d\n",jy.a[i][n]);
  60. }
  61. }

POJ 3233 矩阵快速幂&二分的更多相关文章

  1. poj 3233 矩阵快速幂

    地址 http://poj.org/problem?id=3233 大意是n维数组 最多k次方  结果模m的相加和是多少 Given a n × n matrix A and a positive i ...

  2. Poj 3233 矩阵快速幂,暑假训练专题中的某一道题目,矩阵快速幂的模板

    题目链接  请猛戳~ Description Given a n × n matrix A and a positive integer k, find the sum S = A + A2 + A3 ...

  3. poj 3233 矩阵快速幂+YY

    题意:给你矩阵A,求S=A+A^1+A^2+...+A^n sol:直接把每一项解出来显然是不行的,也没必要. 我们可以YY一个矩阵: 其中1表示单位矩阵 然后容易得到: 可以看出这个分块矩阵的左下角 ...

  4. POJ 3233 Matrix Power Series 矩阵快速幂+二分求和

    矩阵快速幂,请参照模板 http://www.cnblogs.com/pach/p/5978475.html 直接sum=A+A2+A3...+Ak这样累加肯定会超时,但是 sum=A+A2+...+ ...

  5. POJ 3233 Matrix Power Series (矩阵快速幂+二分求解)

    题意:求S=(A+A^2+A^3+...+A^k)%m的和 方法一:二分求解S=A+A^2+...+A^k若k为奇数:S=(A+A^2+...+A^(k/2))+A^(k/2)*(A+A^2+...+ ...

  6. POJ3233:Matrix Power Series(矩阵快速幂+二分)

    http://poj.org/problem?id=3233 题目大意:给定矩阵A,求A + A^2 + A^3 + … + A^k的结果(两个矩阵相加就是对应位置分别相加).输出的数据mod m.k ...

  7. 2017 ECJTU ACM程序设计竞赛 矩阵快速幂+二分

    矩阵 Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 65535/32768K (Java/Other) Total Submission ...

  8. 解题报告:poj 3070 - 矩阵快速幂简单应用

    2017-09-13 19:22:01 writer:pprp 题意很简单,就是通过矩阵快速幂进行运算,得到斐波那契数列靠后的位数 . 这是原理,实现部分就是矩阵的快速幂,也就是二分来做 矩阵快速幂可 ...

  9. HDU 4549 (费马小定理+矩阵快速幂+二分快速幂)

    M斐波那契数列 Time Limit: 1000MS   Memory Limit: 32768KB   64bit IO Format: %I64d & %I64u Submit Statu ...

随机推荐

  1. es6学习 http://es6.ruanyifeng.com/

    基础学习   http://es6.ruanyifeng.com/  够了 1字符串 字符串的遍历器接口 for (let codePoint of 'foo') { console.log(code ...

  2. zmodem使用方法

    无论有xshell还是secureCRT连接linux的时. 默认都用一个zmodem可以帮助window和linux之间传输文件 很方便和实用的工具. 不过默认是无法使用的 需要安装lrzsz软件 ...

  3. 基准测试-jmeter压力测试activeMQ之一环境安装配置

    jmeter压力测试activeMQ 摘要:linux(CentOS)单机activeMQ安装.window(2008Server)Jmeter配置activeMQ包.Jmeter配置linux监控 ...

  4. SaltStact自动化运维工具02

     Grains基础:• Grains是saltstack最重要的组件之一• 存储minion端的基本信息,这些信息一般都是静态的,如CPU.内核.操作系统等• Grains存储在minion本地• 管 ...

  5. day22 包,相对/绝对路径

    目录 包 包被导入时发生的三件事 为什么要有包 相对路径 绝对路径 包 包是一个文件夹,也是一个模块,只是为了区分单个文件的模块,称之为包.因为单纯的文件夹无法作为模块,文件夹内的__init__.p ...

  6. Java 分布式事务

    0 引言 本文主要介绍java中分布式事务以及对应的解决方案. 1 分布式事务产生的原因 1.1 数据库分库分表 当数据库单表一年产生的数据超过1000W,那么就要考虑分库分表,具体分库分表的原理在此 ...

  7. pip是用代理

    内网访问外网时,需要通过vpn访问,但是pip貌似不能是用vpn访问外网.直接度娘: windows下: set http_proxy=http://代理服务器:端口 不行可以试试下面的: set h ...

  8. 【JavaScript框架封装】实现一个类似于JQuery的属性框架的封装

    // 属性框架 (function (xframe) { // 需要参与链式访问的(必须使用prototype的方式来给对象扩充方法) xframe.extend({ /** * 获取/设置某一个元素 ...

  9. BZOJ 3878 [AHOI&JSOI2014]奇怪的计算器 (线段树)

    题面:BZOJ传送门 洛谷传送门 线段树好题 题目保证$a$一定是正整数,容易发现计算结果是单调的 我们把询问离线,并按照从小到大排序 某次操作可能导致某些位置达到边界$L/R$ 根据单调性的结论 这 ...

  10. LINUX 中 VSFTPD安裝

    VSFTPD 简写:vsftpd是very secure FTP daemon 的缩写,是一个完全免费的,开源代码的ftp服务器软件 特点:vsftpd是一款在LINUX发行版中最受推崇的FTP服务器 ...