题目大意:给你$n,k(n\leqslant10^9,k\leqslant10^3)$,求$f_n$。$f$数组满足$f_1=f_2=\cdots=f_k=1$,$f_n=\sum\limits_{i=n-k}^{n-1}f_i$

题解:线性齐次递推:
$$
\left[
\begin{matrix}
f_1&f_2&\cdots&f_k
\end{matrix}
\right]
\left[
\begin{matrix}
0&0&0&\cdots&0&1\\
1&0&0&\cdots&0&1\\
0&1&0&\cdots&0&1\\
0&0&1&\cdots&0&1\\
\vdots&\vdots&\ddots&\ddots&\vdots&\vdots\\
0&0&0&\cdots&1&1
\end{matrix}
\right]
=
\left[
\begin{matrix}
f_2&f_3&\cdots&f_{k+1}
\end{matrix}
\right]
$$
特征多项式$G_k(x)$为:
$$
\begin{align*}
G_k(x)&=|\lambda I-A|\\
&=\left|
\left[
\begin{matrix}
\lambda&0&0&\cdots&0&-1\\
-1&\lambda&0&\cdots&0&-1\\
0&-1&\lambda&\cdots&0&-1\\
0&0&-1&\cdots&0&-1\\
\vdots&\vdots&\ddots&\ddots&\vdots&\vdots\\
0&0&0&\cdots&-1&\lambda-1
\end{matrix}
\right]\right|
\end{align*}
$$
可以对第一行展开
$$
\begin{align*}
G_k(x)&=(-1)^{1+1}\lambda G_{k-1}(x)+(-1)(-1)^{k-1}(-1)^{k+1}\\
&=\lambda G_{k-1}(x)-1\\
&=\lambda^k-\lambda^{k-1}-\lambda^{k-2}-\cdots-1
\end{align*}
$$
发现模数是$10^9+7$,但是$k$只有$10^3$,所以直接$O(k^2)$卷积和取模,总复杂度$O(k^2\log_2n)$

卡点:

C++ Code:

#include <algorithm>
#include <cstdio>
#include <cstring>
#define maxn 2010
const int mod = 1e9 + 7; #define mul(x, y) static_cast<long long> (x) * (y) % mod
inline void reduce(int &x) { x += x >> 31 & mod; } int n, K;
int f[maxn], g[maxn]; void PW(int n) {
if (n == 0) { f[0] = 1; return ; }
PW(n >> 1);
std::memset(g, 0, K << 3);
for (int i = 0; i < K; ++i)
for (int j = 0; j < K; ++j)
reduce(g[i + j + (n & 1)] += mul(f[i], f[j]) - mod);
for (int i = K + K - 1 + (n & 1); i >= K; --i) {
for (int j = 1; j <= K; ++j) reduce(g[i - j] += g[i] - mod);
}
std::memcpy(f, g, K << 2);
} int main() {
scanf("%d%d", &K, &n);
PW(n - 1);
int ans = 0;
for (int i = 0; i < K; ++i) reduce(ans += f[i] - mod);
printf("%d\n", ans);
return 0;
}

  

最新文章

  1. MATLAB的SAVE命令动态批量保存TXT文件
  2. NGUI 屏幕自适应(初始设定宽高800x480只支持比其大的屏幕)
  3. Java.util.ArrayList详解
  4. JavaEE基础(七)
  5. 《PHP扩展开发及内核应用》
  6. Asp.net MVC 视图之公用代码
  7. Shell脚本中单引号(‘)和双引号(“)的使用区别[转载]
  8. JavaScript 语言精粹读书笔记
  9. 麒麟子Cocos Creator实用技巧
  10. ShowDoc上手
  11. fabric.js PatternBrush
  12. PAT Basic 1012
  13. 原生js小球运动
  14. django 多对多 增 删 改 查
  15. java Name [jdbc/myjavadb] is not bound in this Context. Unable to find [jdbc].
  16. PDB自动启动以及Oracle Pfile的参数修改示范
  17. A-作业01
  18. 【BZOJ】3144: [Hnoi2013]切糕
  19. 利用angular指令监听ng-repeat渲染完成后执行脚本
  20. Hulu面试题

热门文章

  1. Scrapy爬取携程桂林问答
  2. flask中的简单的前端写入
  3. RAID系列技术详解
  4. centos7.6 安装配置rabbitmq
  5. Trait 是什么东西
  6. Alpha阶段产品功能说明
  7. 每天学一点easyui①
  8. 软工实践-Beta 冲刺 (2/7)
  9. Ubuntu下ssh连接在服务端显示图形界面
  10. dubbo面向服务使用