poj 3734 矩阵快速幂+YY
题目原意:N个方块排成一列,每个方块可涂成红、蓝、绿、黄。问红方块和绿方块都是偶数的方案的个数。
sol:找规律列递推式+矩阵快速幂
设已经染完了i个方块将要染第i+1个方块。
a[i]=1-i方块中,红、绿方块数量都是偶数的方案数
b[i]=1-i方块中,红、绿方块数量一个是偶数一个是奇数的方案数(红even绿odd 或 红odd绿even)
c[i]=1-i方块中,红、绿方块数量都是奇数的方案数
可以得出递推公式:
a[i+1]=2*a[i]+b[i]
b[i+1]=2*a[i]+2*b[i]+2*c[i]
c[i+1]=b[i]+2*c[i]
如何和矩阵结合起来呢?不妨把公式这样写一遍,
a[i+1]=2*a[i]+1*b[i]+0*c[i]
b[i+1]=2*a[i]+2*b[i]+2*c[i]
c[i+1]=0*a[i]+1*b[i]+2*c[i]
然后可以YY出一个矩阵:
因此,
这样就可以用矩阵快速幂求解了。
- #include "iostream"
- #include "vector"
- #include "cstring"
- using namespace std;
- typedef unsigned long int ULL;
- typedef vector<ULL> vec;
- typedef vector<vec> mat;
- const ULL P=;
- int n,m;
- mat mul(mat &A,mat &B) //return A*B
- {
- mat C(A.size(),vec(B[].size()));
- for (int i=;i<(int)A.size();i++)
- {
- for (int k=;k<(int)B.size();k++)
- {
- for (int j=;j<(int)B[].size();j++)
- {
- C[i][j]=(C[i][j]+A[i][k]*B[k][j])%P;
- }
- }
- }
- return C;
- }
- mat m_pow(mat A,int m) //return A^m
- {
- mat B(A.size(),vec(A.size()));
- for (int i=;i<(int)A.size();i++)
- B[i][i]=;
- while (m>)
- {
- if (m&) B=mul(B,A);
- A=mul(A,A);
- m>>=;
- }
- return B;
- }
- int main()
- {
- int T,N;
- cin>>T;
- while (T--)
- {
- cin>>N;
- mat A(,vec());
- A[][]=; A[][]=; A[][]=;
- A[][]=; A[][]=; A[][]=;
- A[][]=; A[][]=; A[][]=;
- A=m_pow(A,N);
- cout<<A[][]<<endl;
- }
- return ;
- }
- /*
- int main()
- {
- int T;
- cin>>T;
- while (T--)
- {
- cin>>n>>m;
- mat A(n,vec(n));
- for (int i=0;i<n;i++)
- for (int j=0;j<n;j++)
- cin>>A[i][j];
- A=m_pow(A,m);
- ULL ans=0;
- for (int i=0;i<n;i++)
- {
- ans+=A[i][i];
- ans=ans%P;
- }
- cout<<ans<<endl;
- }
- return 0;
- }
- */
poj 3734 矩阵快速幂+YY的更多相关文章
- poj 3233 矩阵快速幂+YY
题意:给你矩阵A,求S=A+A^1+A^2+...+A^n sol:直接把每一项解出来显然是不行的,也没必要. 我们可以YY一个矩阵: 其中1表示单位矩阵 然后容易得到: 可以看出这个分块矩阵的左下角 ...
- Blocks(POJ 3734 矩阵快速幂)
Blocks Input The first line of the input contains an integer T(1≤T≤100), the number of test cases. E ...
- poj 3233 矩阵快速幂
地址 http://poj.org/problem?id=3233 大意是n维数组 最多k次方 结果模m的相加和是多少 Given a n × n matrix A and a positive i ...
- poj 3734 Blocks 快速幂+费马小定理+组合数学
题目链接 题意:有一排砖,可以染红蓝绿黄四种不同的颜色,要求红和绿两种颜色砖的个数都是偶数,问一共有多少种方案,结果对10007取余. 题解:刚看这道题第一感觉是组合数学,正向推了一会还没等推出来队友 ...
- POJ 3070 矩阵快速幂解决fib问题
矩阵快速幂:http://www.cnblogs.com/atmacmer/p/5184736.html 题目链接 #include<iostream> #include<cstdi ...
- 解题报告:poj 3070 - 矩阵快速幂简单应用
2017-09-13 19:22:01 writer:pprp 题意很简单,就是通过矩阵快速幂进行运算,得到斐波那契数列靠后的位数 . 这是原理,实现部分就是矩阵的快速幂,也就是二分来做 矩阵快速幂可 ...
- POJ 3070 矩阵快速幂
题意:求菲波那切数列的第n项. 分析:矩阵快速幂. 右边的矩阵为a0 ,a1,,, 然后求乘一次,就进一位,求第n项,就是矩阵的n次方后,再乘以b矩阵后的第一行的第一列. #include <c ...
- POJ 3233 矩阵快速幂&二分
题意: 给你一个n*n的矩阵 让你求S: 思路: 只知道矩阵快速幂 然后nlogn递推是会TLE的. 所以呢 要把那个n换成log 那这个怎么搞呢 二分! 当k为偶数时: 当k为奇数时: 就按照这么搞 ...
- poj 3744 矩阵快速幂+概率dp
题目大意: 输入n,代表一位童子兵要穿过一条路,路上有些地方放着n个地雷(1<=n<=10).再输入p,代表这位童子兵非常好玩,走路一蹦一跳的.每次他在 i 位置有 p 的概率走一步到 i ...
随机推荐
- throw跟throws关键字
throws关键字 定义一个方法的时候可以使用throws关键字声明.使用throws关键字声明的方法表示此方法不处理异常,而交给方法调用处进行处理. throws关键字格式: public 返回值类 ...
- C语言 const与指针
//const与指针 #include<stdio.h> #include<stdlib.h> void main(){ ; ; const int *p; p = & ...
- IBatis.Net学习笔记五--常用的查询方式
在项目开发过程中,查询占了很大的一个比重,一个框架的好坏也很多程度上取决于查询的灵活性和效率.在IBatis.Net中提供了方便的数据库查询方式. 在Dao代码部分主要有两种方式:1.查询结果为一个对 ...
- 团购、定时抢购倒计时js版
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org ...
- WCF与ASMX Web服务差异比较[译]
First of all, it needs to understand that WCF Service provides all the capabilities of .NET web serv ...
- Android 获取手机Mac地址,手机名称
/** * 获取手机mac地址<br/> * 错误返回12个0 */ public static String getMacAddress(Context context) { // 获取 ...
- MyBatis与Hibernate对比
一.相同点 都屏蔽 jdbc api 的底层访问细节,使用我们不用与 jdbc api 打交道,就可以访问数据. jdbc api 编程流程固定,还将 sql 语句与 java 代码混杂在了一起,经常 ...
- 20145314郑凯杰《信息安全系统设计基础》GDB调试32位汇编堆栈分析
20145314郑凯杰<信息安全系统设计基础>GDB调试32位汇编堆栈分析 本篇博客将对第五周博客中的GDB调试32位汇编堆栈进行分析 首先放上以前环境配置的图: 图1: 测试代码: #i ...
- 从实用主义深入理解c++虚函数
记得几个月前看过C++虚函数的问题,当时其实就看懂了,最近笔试中遇到了虚函数竟然不太确定,所以还是理解的不深刻,所以想通过这篇文章来巩固下. 装逼一刻: 最近,本人思想发生了巨大的转变,在大学的时候由 ...
- on 在ios下 父对象是body的时候会 不调用
on 用委托的形式绑定事件 在ios下 父对象是body 获取 docment的时候会 不调用 解决方案 在这些元素上加 cursor: pointer;