CodeForces 392C Yet Another Number Sequence 矩阵快速幂
题意:
\(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 矩阵快速幂的更多相关文章
- Codeforces 392C Yet Another Number Sequence (矩阵快速幂+二项式展开)
题意:已知斐波那契数列fib(i) , 给你n 和 k , 求∑fib(i)*ik (1<=i<=n) 思路:不得不说,这道题很有意思,首先我们根据以往得出的一个经验,当我们遇到 X^k ...
- UVA - 10689 Yet another Number Sequence 矩阵快速幂
Yet another Number Sequence Let’s define another number sequence, given by the foll ...
- Yet Another Number Sequence——[矩阵快速幂]
Description Everyone knows what the Fibonacci sequence is. This sequence can be defined by the recur ...
- 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 ...
- HDU - 1005 Number Sequence 矩阵快速幂
HDU - 1005 Number Sequence Problem Description A number sequence is defined as follows:f(1) = 1, f(2 ...
- 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 ...
- 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 ...
- SDUT1607:Number Sequence(矩阵快速幂)
题目:http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=1607 题目描述 A number seq ...
- LightOJ 1065 - Number Sequence 矩阵快速幂水题
http://www.lightoj.com/volume_showproblem.php?problem=1065 题意:给出递推式f(0) = a, f(1) = b, f(n) = f(n - ...
随机推荐
- Code First 2
在codefirst一中也说了Mapping是实体与数据库的纽带,model通过Mapping映射到数据库,我们可以从数据库的角度来分析?首先是映射到数据库,这个是必须的.数据库里面一般包括表.列.约 ...
- webpack分开打包和合并打包的瘦身
webpack.config.js 记录一下优化webpack的几个点: 1. devtool: false, //产品阶段不应该有devtool entry: { bundle : pa ...
- 一个例子说明Jsp三大重要内置对象的生命周期
此处Jsp的三大内置对象指:request,session以及application.他们共有的方法:setAttribute,getAttribute,方法名和方法作用都是相同的,但是作用范围不一样 ...
- Linux下环境搭建(四)——jenkins+gitlab+jmeter实践
经过前三篇博文的介绍,jenkins+gitlab+jmeter接口自动化的框架就搭建成功了,详细可见 Linux下环境搭建(一)——java.tomcat配置 Linux下环境搭建(二)——jenk ...
- fiddler设置只抓取某一域名请求
简单易懂~
- 参考消息 Android 读报
<参考消息>是新华通讯社主办,参考消息报社编辑出版的日报,创刊于1931年,历史长达80年.<参考消息>每天及时选载世界各国(地区)通讯社.报刊及因特网上的最新消息.评论的精华 ...
- MVC的验证码
后台: /// <summary> /// 创建验证码的图片 /// </summary> /// <param name="validateCode" ...
- [学习笔记] C++ 历年试题解析(三)--小补充
小小的补充一下吧,因为李老师又把直招的卷子发出来了.. 题目 1.有指针变量定义及初始化int *p=new int[10];执行delete [] p;操作将结束指针变量p的生命期.(×) 解释:试 ...
- VS开发软winform软件的更改用户使用权限
在使用软件的过程中,我们经常需要使用的软件拥有管理员权限,在开发的过程中,本人就遇到了应为权限不足的问题导致软件不能正常使用的状况. 在此我来记录我遇到的问题. 为开发的软件赋予管理员权限 https ...
- VC++:鼠标的使用
长期改变鼠标形状: SetClassLongPtr(GetSafeHwnd(), GCLP_HCURSOR, (LONG)LoadCursor(NULL, IDC_WAIT));//这个是x64下可以 ...