LGP4456题解
我就是不用矩阵快速幂!
题意:一个 \(\rm 01\) 序列为合法的当且仅当没有两个相邻的 \(1\),若 \(1\) 的个数为 \(x\),\(0\) 的个数为 \(y\),这个 \(\rm 01\) 的价值为 \(x^a \times y^b\)。
请求出所有长度为 \(n\) 的 \(\rm 01\) 序列的价值之和,对 \(m\) 取模。
这道题的阴间之处就在于 \(m\) 不一定是质数。。。
首先我们枚举 \(1\) 的个数,可以得到答案为:
\]
如果 \(m\) 是质数的话,这里就可以直接 \(O(n)\) 计算了,可惜并不是。
考虑使用二项式定理展开后者:
\]
\]
现在的问题就是如何处理 \(\sum_{i=0}^{\infty}\binom {n-i+1}ii^k\)。
使用 \(\binom n m=\binom {n-1} m+\binom {n-1}{m-1}\) 展开组合数:
\]
\]
\]
\]
把后面用二项式定理展开:
\]
\]
所以:
\]
如果仔细点儿可以发现这里实际上是在说:
\]
也就是说 $f_{i,j} $ 对 $ f_{n,k}$ 的贡献与斐波那契数列有关,为 \(\binom k jfib_{n-i-2}\)。
接下来就很好办了。
设 \(F_k(x)=\sum_{i=0}^{\infty}f_{i,k}x^i\)
首先很明显,根据定义有 \(F_0(x)=\frac 1 {1-x-x^2}\)。(也就是斐波那契数列)
于是有:
\]
我们可以根据这个直接知道 \(F_1(x)=\frac 1 {(1-x-x^2)^2}\)。
那么 \(F_2(x)\) 呢?
\]
合理猜测 \(F_k(x)\) 的分母为 \((1-x-x^2)^{k+1}\)。
于是我们只维护分子,不维护分母。
那么分子所对应的递推式就应该是 \(H_k(x)=\frac {x^2}{1-x-x^2}\sum_{i=0}^{k-1}\binom k iH_i(x)(1-x-x^2)^{k-i}\)。
于是我们使用类似秦九韶求多项式的值的方法可以做到 \(O(k^3)\) 处理出 \(H_0(x) \sim H_k(x)\),然后再使用常系数齐次线性递推算一下就是和比暴力矩快还慢的\(O((a+b)^3+a(a+b)^2\log n)\) 了。
第二种做法:我们可以列一个 DP 方程,然后用 BM 大力猜出递推式,就可以做到 \(O((a+b)^2\log n)\) 了,好耶!(这里根据直觉猜测递推式的长度就是 a+b)
LGP4456题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
- noip2016十连测题解
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
- BZOJ-2561-最小生成树 题解(最小割)
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
- Codeforces Round #353 (Div. 2) ABCDE 题解 python
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
- 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
- 2016ACM青岛区域赛题解
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
- poj1399 hoj1037 Direct Visibility 题解 (宽搜)
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
- 网络流n题 题解
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
- CF100965C题解..
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
随机推荐
- json解析出现:java.lang.ClassCastException: net.sf.ezmorph.bean.MorphDynaBean cannot be cast to XXX
感谢大佬:https://blog.csdn.net/one_ink/article/details/99817676 一.出错原因 当我们利用json解析中的toBean方法时,如果它的属性里面包含 ...
- laravel 依赖注入 接口设计
假设我现在需要做一个支付服务,那么我先设计一个接口 interface PayInterface{ public function pay(Order $order) : string; } 然后实现 ...
- 计算机网络再次整理————tcp周边[八]
前言 tcp的包的格式可以看我以前的计算机网络整理,下面这些周边只是为了开发时候我们能用到一些理论知识. 正文 首先要介绍的就是域名,为啥有域名这东西呢?单纯站在网络的角度上讲这属于应用层的东西了. ...
- 7、前端--jQuery简介、基本选择器、基本筛选器、属性选择器、表单选择器、筛选器方法、节点操作、绑定事件
jQuery简介 宗旨:Write less, do more. 内部封装了js代码 是编程更加简单并且兼容所有的主流浏览器 版本:1.x 2.x 3.x # 可以使用3.x最新版 是第三方的类库:使 ...
- 深入MySQL(四):MySQL的SQL查询语句性能优化概述
关于SQL查询语句的优化,有一些一般的优化步骤,本节就介绍一下通用的优化步骤. 一条查询语句是如何执行的 首先,我们如果要明白一条查询语句所运行的过程,这样我们才能针对过程去进行优化. 参考我之前画的 ...
- CPU、进程、线程原理
巨人的肩膀 看完这篇还不懂高并发中的线程与线程池你来打我 (qq.com)
- DevOpts 前端开发和 Spug
DevOpts 前端开发和 Spug 朋友新工作是进行 DevOpts 前端开发,涉及 Spug. DevOps 是什么 DevOps 是一种思想.用于促进开发和运维之间的沟通.协作或整合. Tip: ...
- 搭建开源跳板机——jumpserver
搭建开源跳板机mobaxterm 官方文档:https://jumpserver.readthedocs.io/zh/master/ $ yum update -y # 防火墙 与 selinux 设 ...
- java培训班出来的都怎么样了
通过java培训班培训这种方式来提升自身技能,然后找到工作,是现在许多刚毕业或是想转行的从业者选择的途径之一,在这种趋势之下,许多相关人士都非常关注从java培训班出来的人们结果是否令人满意. 不可否 ...
- BGP4+协议测试——信而泰网络测试仪实操
文章关键词 BGP4+协议:路由协议:协议测试: 一.前言: 为了有效管理高速发展的互联网,而将其划分为多个相对独立的网格,称为自治域(AS).AS之间通过外部网关协议(EGP)来交换网路可达性信息, ...