题目链接:点击查看

题目大意:中文题意,不难理解

题目分析:正解是需要给原函数求导,用矩阵快速幂求出导函数差分后的值,再推出原函数的值(我是没看懂,毕竟是防ak的题),但后来lb学长来问我能不能用BM做,我一脸疑惑:什么是BM?去学了一波黑科技后,发现可以用BM导入前500项然后水过去。。我就说为什么这个题比赛的时候过的人数那么多

代码:

#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <vector>
#include <string>
#include <map>
#include <set>
#include <cassert>
using namespace std;
#define rep(i,a,n) for (int i=a;i<n;i++)
#define per(i,a,n) for (int i=n-1;i>=a;i--)
#define pb push_back
#define mp make_pair
#define all(x) (x).begin(),(x).end()
#define fi first
#define se second
#define SZ(x) ((int)(x).size())
typedef vector<int> VI;
typedef long long ll;
typedef pair<int,int> PII;
const ll mod=998244353;
ll powmod(ll a,ll b)
{ll res=1;a%=mod;assert(b>=0);for(;b;b>>=1){if(b&1)res=res*a%mod;a=a*a%mod;}return res;
}
int _,n;
namespace linear_seq
{const int N=10010;ll res[N],base[N],_c[N],_md[N];vector<int> Md;void mul(ll *a,ll *b,int k) {for(int i = 0 ; i < k + k ; ++i)_c[i]=0;for(int i = 0 ; i < k ;++i)if (a[i])for(int j = 0 ;j < k ;++ j)_c[i+j]=(_c[i+j]+a[i]*b[j])%mod;for (int i=k+k-1;i>=k;i--)if (_c[i])for(int j = 0 ; j<(int ) Md.size() ; ++ j)_c[i-k+Md[j]]=(_c[i-k+Md[j]]-_c[i]*_md[Md[j]])%mod;for(int i =0 ; i< k ; ++i)a[i]=_c[i];}int solve(ll n,VI a,VI b) {ll ans=0,pnt=0;int k=SZ(a);assert( SZ(a) == SZ(b) );for(int i = 0 ;i < k ; ++ i)_md[k-1-i] = -a[i] ; _md[k] = 1 ;Md.clear() ;for(int i =0 ; i < k ; ++ i)if (_md[i]!=0)Md.push_back(i);for(int i = 0; i< k ;++ i)res[i]=base[i]=0;res[0]=1;while ((1ll<<pnt)<=n)pnt++;for (int p=pnt;p>=0;p--) {mul(res,res,k);if ((n>>p)&1) {for (int i=k-1;i>=0;i--) res[i+1]=res[i];res[0]=0;for(int j = 0 ;j < (int)Md.size() ; ++ j)res[ Md[j] ]=(res[ Md[j] ]-res[k]*_md[Md[j]])%mod;}}rep(i,0,k) ans=(ans+res[i]*b[i])%mod;if (ans<0) ans+=mod;return ans;}VI BM(VI s) {VI C(1,1),B(1,1);int L=0,m=1,b=1;for(int n= 0 ;n < (int)s.size(); ++ n ) {ll d=0;for(int i =0 ; i < L +1 ;++ i)d=(d+(ll)C[i]*s[n-i])%mod;if (d==0) ++m;else if (2*L<=n) {VI T=C;ll c=mod-d*powmod(b,mod-2)%mod;while (SZ(C)<SZ(B)+m)C.push_back(0);for(int i =0 ; i < (int)B.size(); ++ i)C[i+m]=(C[i+m]+c*B[i])%mod;L=n+1-L; B=T; b=d; m=1;} else {ll c=mod-d*powmod(b,mod-2)%mod;while (SZ(C)<SZ(B)+m)C.push_back(0);for(int i = 0 ;i <(int) B.size() ; ++ i)C[i+m]=(C[i+m]+c*B[i])%mod;++m;}}return C;}ll gao(VI a,ll n) {VI c=BM(a);c.erase(c.begin());for( int i = 0 ; i < (int)c.size( );++i )c[i]=(mod-c[i])%mod;return (ll)solve(n,c,VI(a.begin(),a.begin()+SZ(c)));}
};ll fib[510];void init()
{fib[1]=1;fib[2]=1;for(int i=3;i<=500;i++)fib[i]=(fib[i-1]+fib[i-2])%mod;
}int main() {init();VI a;ll n,k;scanf("%lld%lld",&n,&k);ll ans=0;for(int i=1;i<=500;i++){ans=(ans+powmod(i,k)*fib[i]%mod)%mod;a.push_back(ans);}printf("%lld\n",linear_seq::gao(a,n-1));return 0 ;
}

牛客 - 斐波那契和(杜教BM)相关推荐

  1. 【计蒜客系列】挑战难题4:简单斐波那契

    题目来源:计蒜客 斐波那契数列是一种非常有意思的数列,由 0 和 1 开始,之后的斐波那契系数就由之前的两数相加.用数学公式定义斐波那契数列则可以看成如下形式: F0=0 F1=1 Fn=Fn-1+F ...

  2. 斐波那契数列相关简化4

    看这篇文章前需要看下前面三篇文章,最起码第一第二篇是需要看一下的 斐波那契数列数列相关简化1_鱼跃鹰飞的博客-CSDN博客 斐波那契数列数列相关简化2_鱼跃鹰飞的博客-CSDN博客 斐波那契数列数列相 ...

  3. 牛客网-斐波那契数列

    牛客网编程题–>大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0),其中n<=39. 用递归结构写斐波那契数列. #include < ...

  4. 牛客15666 又见斐波那契(矩阵快速幂)

    链接:https://ac.nowcoder.com/acm/problem/15666 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536 ...

  5. 牛客18987 粉嘤花之恋(矩阵快速幂、斐波那契数列)

    链接:https://ac.nowcoder.com/acm/problem/18987 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32768K,其他语言65536 ...

  6. 牛客网 斐波那契数列

    剑指offer 牛客网 斐波那契数列 # -*- coding: utf-8 -*- """ Created on Mon Apr 8 15:35:14 2019@aut ...

  7. 牛客网 NC200607 A-解锁专家 斐波那契数列

    文章目录 1. 题目描述 1.1. Limit 1.2. Problem Description 1.3. Input 1.4. Output 1.5. Sample Input 1.6. Sampl ...

  8. 斐波那契数列前20项_牛客网 NC200607 A-解锁专家 斐波那契数列

    目录 目录 1. 题目描述 1.1. Limit 1.2. Problem Description 1.3. Input 1.4. Output 1.5. Sample Input 1.6. Samp ...

  9. 牛客网(剑指offer) 第七题 斐波那契数列

    //问题描述: 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项. n<=39 function Fibonacci($n){//显然递归超时了 2333333333 ...

最新文章

  1. ORACLE SQL: 经典查询练手第二篇
  2. Apache安装及jboss部署说明文档
  3. 《第一行代码》学习笔记40-网络(1)
  4. Lua学习教程之 可变參数数据打包与解包
  5. 在Apworks数据服务中使用基于Entity Framework Core的仓储(Repository)实现
  6. bootstrp-table 获取checkbox选中行的数据id
  7. jmeter压力测试_用Jmeter实现对接口的压力测试
  8. Office 2007在安装过程中出错
  9. 利用sender的Parent获取GridView中的当前行
  10. 国内PHP,ASP免费开源的CMS介绍
  11. RTCM—CRC校验
  12. 基于主从博弈的电热综合能源系统动态定价与能量管理 主要做的是电热综合能源系统的动态定价问题,采用是主从博弈方法
  13. jmeter分布式部署
  14. knockoutjs 读源码
  15. 基于计算机视觉原理的自主足球机器人位置规划,基于计算机视觉原理的自主足球机器人位置规划...
  16. 51单片机-串行口通信实验
  17. c# excel文档导入及excel存储数据库
  18. PHP开发基于Mirai的QQ机器人
  19. idea快速搭建ssm框架
  20. textpad:工具中没有编译

热门文章

  1. python数学建模可视化_数学建模之流程图和数据可视化
  2. CORS 跨域-哪些操作受到同源限制
  3. Nginx七层负载均衡配置
  4. Nginx server_name精确匹配配置
  5. 在Spring 框架中如何更有效的使用JDBC?
  6. 文件到集合改进版【应用】
  7. 权限管理-整合SpringSecurity
  8. RocketMQ快速入门之消息过滤器(用户自定义属性)
  9. SpringBoot创建SpringBoot项目以及启动器讲解
  10. Session的底层实现原理