题意:

\(F_n\)为斐波那契数列,\(F_1=1,F_2=2\)。

给定一个\(k\),定义数列\(A_i=F_i \cdot i^k\)。

求\(A_1+A_2+ \cdots + A_n\)。

分析:

构造一个列向量,

\({\begin{bmatrix}
F_{i-1}i^0 &
F_{i-1}i^1 &
\cdots &
F_{i-1}i^k &
F_{i}i^0 &
F_{i}i^1 &
\cdots &
F_{i}i^k &
S_{i-1}
\end{bmatrix}}^T\)

转移到列向量:

\({\begin{bmatrix}
F_{i}i^0 &
F_{i}i^1 &
\cdots &
F_{i}i^k &
F_{i+1}i^0 &
F_{i+1}i^1 &
\cdots &
F_{i+1}i^k &
S_{i}
\end{bmatrix}}^T\)

上半部分直接复制到上面去即可,考虑下半部分:

\(F_{i+1}(i+1)^k=(F_{i-1}+F_i)(i+1)^k=F_{i-1}\left [ (i-1)+2 \right ]^k + F_i(i+1)^k=F_{i-1} \sum C_k^j (i-1)^j 2^{k-j} + F_i \sum C_k^j i^j\)

最后\(S_i=S_{i-1}+F_i i^k\)

预处理一下组合数,按照上面的系数构造矩阵即可。

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; typedef long long LL; const LL MOD = 1000000007;
const int maxsz = 90; LL n;
int k, sz; LL mul(LL a, LL b) { return a * b % MOD; }
LL add_mod(LL a, LL b) { a += b; if(a >= MOD) a -= MOD; return a; }
void add(LL& a, LL b) { a += b; if(a >= MOD) a -= MOD; } struct Matrix
{
LL a[maxsz][maxsz]; Matrix() { memset(a, 0, sizeof(a)); } Matrix operator * (const Matrix& t) const {
Matrix ans;
for(int i = 0; i < sz; i++)
for(int j = 0; j < sz; j++)
for(int k = 0; k < sz; k++)
add(ans.a[i][j], mul(a[i][k], t.a[k][j]));
return ans;
} void output() {
printf("sz = %d\n", sz);
for(int i = 0; i < sz; i++) {
for(int j = 0; j < sz - 1; j++)
printf("%d ", a[i][j]);
printf("%d\n", a[i][sz - 1]);
}
}
}; Matrix pow_mod(Matrix a, LL p) {
Matrix ans;
for(int i = 0; i < sz; i++) ans.a[i][i] = 1;
while(p) {
if(p & 1) ans = ans * a;
a = a * a;
p >>= 1;
}
return ans;
} LL C[45][45], a[maxsz]; void process() {
for(int i = 0; i <= 40; i++) C[i][i] = C[i][0] = 1;
for(int i = 2; i <= 40; i++)
for(int j = 1; j < i; j++)
C[i][j] = add_mod(C[i-1][j-1], C[i-1][j]);
} int main()
{
process();
scanf("%lld%d", &n, &k);
sz = k * 2 + 3; for(int i = 0; i <= k; i++) {
a[i] = 1;
a[i + k + 1] = ((1LL << (i + 1)) % MOD);
}
a[sz - 1] = 1; Matrix M;
for(int i = 0; i <= k; i++) M.a[i][i + k + 1] = 1;
for(int i = 0; i <= k; i++)
for(int j = 0; j <= i; j++) {
M.a[i+k+1][j+k+1] = C[i][j];
M.a[i+k+1][j] = mul(C[i][j], ((1LL << (i - j)) % MOD));
}
M.a[sz-1][sz-2] = M.a[sz-1][sz-1] = 1; M = pow_mod(M, n - 1); LL ans = 0;
for(int i = 0; i < sz; i++)
add(ans, mul(M.a[sz-1][i], a[i])); printf("%lld\n", ans); return 0;
}

CodeForces 392C Yet Another Number Sequence 矩阵快速幂的更多相关文章

  1. Codeforces 392C Yet Another Number Sequence (矩阵快速幂+二项式展开)

    题意:已知斐波那契数列fib(i) , 给你n 和 k , 求∑fib(i)*ik (1<=i<=n) 思路:不得不说,这道题很有意思,首先我们根据以往得出的一个经验,当我们遇到 X^k ...

  2. UVA - 10689 Yet another Number Sequence 矩阵快速幂

                      Yet another Number Sequence Let’s define another number sequence, given by the foll ...

  3. Yet Another Number Sequence——[矩阵快速幂]

    Description Everyone knows what the Fibonacci sequence is. This sequence can be defined by the recur ...

  4. HDU 1005 Number Sequence(矩阵快速幂,快速幂模板)

    Problem Description A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1 ...

  5. HDU - 1005 Number Sequence 矩阵快速幂

    HDU - 1005 Number Sequence Problem Description A number sequence is defined as follows:f(1) = 1, f(2 ...

  6. HDU - 1005 -Number Sequence(矩阵快速幂系数变式)

    A number sequence is defined as follows:  f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) m ...

  7. Yet another Number Sequence 矩阵快速幂

    Let’s define another number sequence, given by the following function: f(0) = a f(1) = b f(n) = f(n ...

  8. SDUT1607:Number Sequence(矩阵快速幂)

    题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=1607 题目描述 A number seq ...

  9. LightOJ 1065 - Number Sequence 矩阵快速幂水题

    http://www.lightoj.com/volume_showproblem.php?problem=1065 题意:给出递推式f(0) = a, f(1) = b, f(n) = f(n - ...

随机推荐

  1. Java中的日志框架

    日志框架的介绍和使用 常见的日志框架:JUL(Java.util.logging),JCL(jakarta commons logging),SLF4J,jboss-logging,Log4j,Log ...

  2. codevs 4888 零件分组

    4888 零件分组  时间限制: 1 s  空间限制: 16000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 现有一些棍状零件,每个零件都有 ...

  3. iOS VIPER架构(一)

    洋葱模型 洋葱模型,是从冰山模型上演变而来的,用来进行层次分析的模型,这是Redux的洋葱模型. action从最外层传入,层层传递直至核心后,经过逐层事件触发,再次被分发出来,执行后续操作. 洋葱模 ...

  4. windows下安装pm2

    安装pm2 npm install pm2 -g 添加系统环境变量 PM2_HOME=C:\Users\PCONE\.pm2 打开新的cmd命令行窗口,执行以下命令来安装服务 pm2-service- ...

  5. cmd_ping命令

    ping命令是网络命令里的核心命令,同时也是黑客入侵的基础命令.下面和大家分享一下ping命令的基础知识和一般用法. 以ping百度公司域名为例,介绍ping命令相关内容. 一.ping命令基础知识 ...

  6. Java中protected方法访问权限的问题

    先看Test.java 此时出现上文提到的错误:The method clone from the type Object is not visiuable. 我们已经清楚Object.clone() ...

  7. Codeforces 786E. ALT 最小割+倍增

    E. ALT http://codeforces.com/problemset/problem/786/E 题意: 给出一棵 n 个节点的树与 m 个工人.每个工人有一条上下班路线(简单路径),一个工 ...

  8. Java 集合框架_中

    Set接口 特点: [1]Set接口表示一个唯一.无序的容器(和添加顺序无关) Set接口常用实现类有 HashSet [1]HashSet是Set接口的实现类,底层数据结构是哈希表. [2]Hash ...

  9. shell的切换

    从zsh切换到bash:在命令行输入bash即可 从bash切换到zsh:在命令行输入zsh即可

  10. MySQL Innodb表空间不足的处理方法

    官方给出的解决方案: 添加和删除 InnoDB 数据和日志文件 这一节描述在InnoDB表空间耗尽空间之时,或者你想要改变日志文件大小之时,你可以做的一些事情. 最简单的,增加InnoDB表空间大小的 ...