感觉像是HDU Keyboard的加强版,先推出3张牌时的所有组合,然后递推出n张牌

看到n=1e18时吓尿了

最后24那里还是推错了..

(5行1列 dp[1][n],dp[2][n],dp[3][n],dp[4][n],dp[5][n]) = A^(n-3) * (5行1列 4,12,12,12,24)

其中,A=

1,0,0,1,0

3,0,0,3,0

0,1,1,0,1

0,1,1,0,1

0,2,2,0,1

#include<bits/stdc++.h>
#define rep(i,j,k) for(register int i=j;i<=k;i++)
using namespace std;
typedef long long ll;
const int maxn = 100;
const ll MOD = 1e9+9;
inline ll mod(ll a){return a%MOD;}
int b[6][6]={
{0,0,0,0,0,0},
{0,1,0,0,1,0},
{0,3,0,0,3,0},
{0,0,1,1,0,1},
{0,0,1,1,0,1},
{0,0,2,2,0,1},
};
ll c[6]={0,4,12,12,12,24};
struct Mat{
ll m[7][7],r,c;
void node(int rr,int cc,bool unit=0){
r=rr;c=cc;
memset(m,0,sizeof m);
if(unit) rep(i,1,rr) m[i][i]=1;
}
};
Mat operator * (Mat a,Mat b){
Mat ans;ans.node(a.r,b.c);
rep(i,1,a.r){
rep(j,1,b.c){
int t=max(a.r,b.c);
rep(k,1,t){
ans.m[i][j]+=mod(a.m[i][k]*b.m[k][j]);
ans.m[i][j]=mod(ans.m[i][j]);
}
}
}
return ans;
}
Mat qmod(Mat a,ll n){
Mat ans;ans.node(5,5,1);
while(n){
if(n&1) ans=ans*a;
n>>=1;
a=a*a;
}
return ans;
}
ll qmod(ll a,ll n){
ll ans=1;
while(n){
if(n&1) ans=mod(mod(ans)*mod(a));
n>>=1;
a=mod(mod(a)*mod(a));
}
return mod(ans);
}
int main(){
ll n;
Mat base,base2; base.node(5,5); base2.node(5,1);
rep(i,1,5) rep(j,1,5) base.m[i][j]=b[i][j];
rep(i,1,5) base2.m[i][1]=c[i];
while(scanf("%lld",&n)!=EOF){
Mat tmp=qmod(base,n-3);
Mat res=tmp*base2;
ll ans=0;
rep(i,1,5) {ans+=mod(res.m[i][1]);ans=mod(ans);}
ans=mod(qmod(4,n)-ans);
printf("%lld\n",ans<0?ans+MOD:ans);
}
return 0;
}

UESTC - 1610 递推方程+矩阵快速幂的更多相关文章

  1. [HDOJ2604]Queuing(递推,矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2604 递推式是百度的,主要是练习一下如何使用矩阵快速幂优化. 递推式:f(n)=f(n-1)+f(n- ...

  2. hihoCoder 1143 : 骨牌覆盖问题·一(递推,矩阵快速幂)

    [题目链接]:click here~~ 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题: 我们有一个2xN的长条形 ...

  3. HDU - 2604 Queuing(递推式+矩阵快速幂)

    Queuing Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  4. HDU5950 Recursive sequence 非线性递推式 矩阵快速幂

    题目传送门 题目描述:给出一个数列的第一项和第二项,计算第n项. 递推式是 f(n)=f(n-1)+2*f(n-2)+n^4. 由于n很大,所以肯定是矩阵快速幂的题目,但是矩阵快速幂只能解决线性的问题 ...

  5. hdu 5950 Recursive sequence 递推式 矩阵快速幂

    题目链接 题意 给定\(c_0,c_1,求c_n(c_0,c_1,n\lt 2^{31})\),递推公式为 \[c_i=c_{i-1}+2c_{i-2}+i^4\] 思路 参考 将递推式改写\[\be ...

  6. [题解][SHOI2013]超级跳马 动态规划/递推式/矩阵快速幂优化

    这道题... 让我见识了纪中的强大 这道题是来纪中第二天(7.2)做的,这么晚写题解是因为 我去学矩阵乘法啦啦啦啦啦对矩阵乘法一窍不通的童鞋戳链接啦 层层递推会TLE,正解矩阵快速幂 首先题意就是给你 ...

  7. HDU-6185-Covering(推递推式+矩阵快速幂)

    Covering Time Limit: 5000/2500 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

  8. hdu 6185 递推+【矩阵快速幂】

    <题目链接> <转载于 >>> > 题目大意: 让你用1*2规格的地毯去铺4*n规格的地面,告诉你n,问有多少种不同的方案使得地面恰好被铺满且地毯不重叠.答案 ...

  9. 【图灵杯 F】一道简单的递推题(矩阵快速幂,乘法模板)

    Description 存在如下递推式: F(n+1)=A1*F(n)+A2*F(n-1)+-+An*F(1) F(n+2)=A1*F(n+1)+A2*F(n)+-+An*F(2) - 求第K项的值对 ...

随机推荐

  1. Linux 下五款出色的流媒体客户端

    数 字流媒体这几天几乎占据了我音乐收听的全部时间.近年来我为了收藏 CD 花费了数量可观的费用:但它们中的大部分现在正静静地躺在满是灰尘的角落里.基本上所有的音乐流媒体服务所提供的的音质都不如 CD ...

  2. ubuntu 设置虚拟机和主机在同一网段

    一.在VMware中将网络连接方式设置为桥接 1.打开VM菜单栏->Settings 2.在弹出的Virtual Machine Setting对话框中点击Network Adapter,在右边 ...

  3. 15.select into

    select into SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中. SELECT INTO 语句常用于创建表的备份复件或者用于对记录进行存档. CREATE TABLE ...

  4. 2.sql分类

    SQL DML 和 DDL 可以把 SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL). SQL (结构化查询语言)是用于执行查询的语法.但是 SQL 语言也包含用于更新.插 ...

  5. 2.2开源的魅力:编译opencv源代码

    1.下载安装CMake 要在Windows平台下生成opencv的解决方案,需要一个名为CMake的开源软件.CMake的全称是crossplatform make.它是一个跨平台的安装(编译)工具, ...

  6. jQuery插件编写学习+实例——无限滚动

    最近自己在搞一个网站,需要用到无限滚动分页,想想工作两年有余了,竟然都没有写过插件,实在惭愧,于是简单学习了下jQuery的插件编写,然后分享出来. 先说下基础知识,基本上分为两种,一种是对象级别的插 ...

  7. 一个数组:1,1,2,3,5,8,13,21...+m,求第30位数是多少?用递归实现;(常考!!!)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  8. 以太坊系列之十四: solidity特殊函数

    solidity中的特殊函数 括号里面有类型和名字的是参数,只有类型是返回值. block.blockhash(uint blockNumber) returns (bytes32): hash of ...

  9. Java高质量代码之 — 泛型与反射

    在Java5后推出了泛型,使我们在编译期间操作集合或类时更加的安全,更方便代码的阅读,而让身为编译性语言的Java提供动态性的反射技术,更是在框架开发中大行其道,从而让Java活起来,下面看一下在使用 ...

  10. EF 热加载 Winform/Asp.net

    public partial class Form1 : Form { BackgroundWorker worker = new BackgroundWorker(); xxContext cont ...